# μCOM-75x Family 4-bit CMOS Microcomputer User's Manual Volume II | Standard 4-bit Microcomputer μPD75004/006/008 | | |-------------------------------------------------------------------------------------|--| | Standard 4-bit Microcomputer with FIP Controller/Driver<br>µPD75268 | | | Standard 4-bit Microcomputer with LCD Controller/Driver<br>µPD75304/306/308/312/316 | | | Standard 4-bit Microcomputer with LCD Controller/Driver | | and A/D Converter μPD75328 μCOM-75X Family Standard Instruction Set Low End 4-bit Microcomputer $\mu$ PD75402A 3 6 ## **Contents** | | apter<br>Indar | 1<br>d 4-bit Microcomputer μPD75004/006/008 | Pa | age | |----|----------------|----------------------------------------------------|--------|-----| | 1. | Ove | view | II-1- | 1 | | | 1.1 | Features | II-1- | 1 | | | 1.2 | Ordering information | II-1- | 3 | | | 1.3 | Functional differences between family products | 11-1- | 3 | | | 1.4 | Block diagram | | | | | 1.5 | Pin configuration (Top View) | II-1- | 5 | | 2. | | function | | | | 3. | Arch | itecture and memory map | II-1- | 15 | | | 3.1 | Data memory bank configuration and addressing mode | II-1- | 15 | | | 3.2 | Memory mapped I/O | II-1- | 26 | | 4. | Inter | nal CPU function | II-1- | 29 | | | 4.1 | Program counter (PC) | 11-1- | 29 | | | 4.2 | Program memory (ROM) | II-1- | 30 | | | 4.3 | Data memory (RAM) | II-1- | 34 | | | 4.4 | General purpose register | II-1- | 35 | | | 4.5 | Accumulator | | | | | 4.6 | Stack pointer (SP) | II-1- | 36 | | | 4.7 | Program status word (PSW) | II-1- | 39 | | | 4.8 | Bank selection register (BS) | 11-1- | 41 | | 5. | Peri | pheral hardware function | II-1- | 42 | | | 5.1 | Digital input/output ports | | | | | 5.2 | Clock generator | 11-1- | 55 | | | 5.3 | Basic interval timer | II-1- | 62 | | | 5.4 | Watch timer | 11-1- | 66 | | | 5.5 | Timer/event counter configuration | II-1- | 68 | | | 5.6 | Serial interface | | | | | 5.7 | Bit sequential buffer | II-1-1 | 104 | | | | | Page | |-----|--------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------| | 6. | Inter<br>6.1<br>6.2<br>6.3<br>6.4<br>6.5<br>6.6<br>6.7 | rupt function | II-1-105<br>II-1-105<br>II-1-107<br>II-1-109<br>II-1-114<br>II-1-115<br>II-1-115<br>II-1-116 | | | 6.9 | Interrupt applications | | | 7. | Stan<br>7.1<br>7.2<br>7.3<br>7.4 | dby function | II-1-122<br>II-1-123<br>II-1-125 | | 8. | RES | ET function | II-1-129 | | 9. | Elect | rical characteristics Package information | | | 10. | μPD7<br>10.1<br>10.2<br>10.3<br>10.4<br>10.5<br>10.6<br>10.7 | 75P008 4-bit microcomputer (OTPROM version) | II-1-152<br>II-1-153<br>II-1-154<br>II-1-155<br>II-1-160 | | 11. | | rical characteristics µPD75P008 | | | Sta | | 2<br>d 4-bit Microcomputer with FIP<br>er/Driver μPD75268 | Pŧ | age | |-----|-------|-----------------------------------------------------------|-------|-----| | 1. | Ove | rview | 11-2- | 1 | | | 1.1 | Features | 11-2- | 1 | | | 1.2 | Ordering information | 11-2- | 1 | | | 1.3 | List of functions | 11-2- | 2 | | | 1.4 | Functions of the products in the family | II-2- | 3 | | | 1.5 | Block diagram | 11-2- | 4 | | | 1.6 | Pin diagram | II-2- | 5 | | 2. | Pin f | function | II-2- | 7 | | 3. | Arch | nitecture and memory map | 11-2- | 15 | | - | 3.1 | Data memory bank structure and addressing modes | | | | | 3.2 | Memory-mapped I/O | | | | 4. | Inter | rnal CPU function | 11-2- | 28 | | | 4.1 | Program counter | | | | | 4.2 | Program memory | | - | | | 4.3 | Data memory | | | | | 4.4 | General-purpose registers | | | | | 4.5 | Accumulator | | | | | 4.6 | Stack pointer | | | | | 4.7 | Program status word | | | | | 4.8 | Bank select register | II-2- | 38 | | 5. | Peri | pheral hardware function | II-2- | 39 | | | 5.1 | Digital input/output ports | | | | | 5.2 | Clock generator | | | | | 5.3 | Basic interval timer | 11-2- | 55 | | | 5.4 | Watch timer | II-2- | 58 | | | 5.5 | Timer/event counter | II-2- | 60 | | | 5.6 | Serial interface | II-2- | 68 | | | 5.7 | FIP controller/driver | 11-2- | 77 | | | | | Pa | age | |----|------|---------------------------------------------------|-------|-----| | 6. | Inte | rrupt function | 11-2- | 90 | | | 6.1 | Configuration of the interrupt control circuit | 11-2- | 90 | | | 6.2 | Hardware for interrupt control circuit | II-2- | 93 | | | 6.3 | Interrupt sequence | II-2- | 97 | | | 6.4 | Shared vector address interrupt service | 11-2- | 98 | | | 6.5 | Machine cycles for starting interrrupt processing | 11-2- | 99 | | | 6.6 | Effective use of interrupts | | | | | 6.7 | Interrupt applications | II-2- | 100 | | 7. | Star | ndby function | 11-2- | 106 | | | 7.1 | Setting of standby modes and operation status | 11-2- | 106 | | | 7.2 | Releasing standby mode | II-2- | 107 | | | 7.3 | Operating after standby mode is released | 11-2- | 109 | | | 7.4 | Application of standby mode | | | | 8. | RES | ET function | 11-2- | 113 | | 9. | Elec | etrical characteristics | 11-2- | 114 | | | 9.1 | Package information | 11-2- | 128 | | Sta | | 3<br>d 4-bit Microcomputer with LCD<br>er/Driver μPD75304/306/308/312/316 | Pa | age | |-----|-------|---------------------------------------------------------------------------|--------|-----| | 1. | Ove | view | 11-3- | 1 | | | 1.1 | Features | | - | | | 1.2 | Ordering information | | | | | 1.3 | List of family product functions | | | | | 1.4 | Block diagram | | | | | 1.5 | Pin connection | | | | 2. | Pin f | unction | II-3- | 7 | | 3. | Arch | itecture and memory map | II-3- | 20 | | | 3.1 | Data memory bank configuration and addressing modes | | | | | 3.2 | Memory mapped I/O | II-3- | 31 | | 4. | Inter | nal CPU function | II-3- | 34 | | | 4.1 | Program counter | II-3- | 34 | | | 4.2 | Program memory (ROM) | II-3- | 35 | | | 4.3 | Data memory (RAM) | 11-3- | 41 | | | 4.4 | General purpose registers | II-3- | 43 | | | 4.5 | Accumulator | II-3- | 44 | | | 4.6 | Stack pointer | II-3- | 44 | | | 4.7 | Program status word | II-3- | 48 | | | 4.8 | Bank selection register | | | | 5. | Peri | pheral hardware function | II-3- | 51 | | | 5.1 | Digital input/output ports | II-3- | 51 | | | 5.2 | Clock generator | | | | | 5.3 | Basic interval timer | II-3- | 71 | | | 5.4 | Watch timer | II-3- | 75 | | | 5.5 | Timer/event counter configuration | II-3- | 77 | | | 5.6 | Serial interface | | | | | 5.7 | LCD controller/driver | II-3-1 | 112 | | | 5.8 | Rit seguential huffer | | | | | | | Page | |----|-------|-------------------------------------------------|----------| | 6. | Inter | rupt function | II-3-138 | | | 6.1 | Interrupt control circuit configuration | | | | 6.2 | Interrupt source types and vector table | II-3-140 | | | 6.3 | Hardware devices of interrupt control circuit | II-3-142 | | | 6.4 | Interrupt sequence | II-3-147 | | | 6.5 | Multi interrupt service control | II-3-148 | | | 6.6 | Vector address share interrupt service | II-3-148 | | | 6.7 | Machine cycles to interrupt service start | II-3-149 | | | 6.8 | Effective use of interrupts | II-3-149 | | | 6.9 | Interrupt application | II-3-150 | | 7 | Stan | dby function | II-3-155 | | | 7.1 | Standby mode setting and operating state | II-3-155 | | | 7.2 | Releasing standby mode | II-3-156 | | | 7.3 | Operation after standby mode is released | II-3-158 | | | 7.4 | Application of standby mode | | | 8. | RES | ET function | II-3-162 | | 9. | Elect | trical characteristics | II-3-164 | | • | 9.1 | Package information | | | 10 | uPD: | 75P308/P316 OTPROM/UVPROM | | | | | microcomputer | II-3-184 | | | 10.1 | Overview | | | | 10.2 | Features | | | | 10.3 | Block diagram | | | | 10.4 | Pin configuration | | | | 10.5 | Pin functions | | | | 10.6 | Differences between μPD75P308/P316 and μPD753XX | | | | 10.7 | PROM write and verification | | | | 10.8 | Electrical characteristics | | | | 10.9 | | | #### Chapter 4 Standard 4-bit Microcomputer with LCD Controller/Driver and A/D Converter µPD75328 Page 1. Overview...... II-4-1.1 Features II-4-1.2 Ordering information...... II-4-3 1.3 List of family product functions ...... II-4-3 1.4 Block diagram ..... II-4-1.5 Pin connection ..... II-4-5 2. Pin function ..... II-4-Input and output ports ..... II-4-2.1 2.2 Pin function list ...... II-4-2.3 Pin input/output circuits ...... II-4- 12 Processing of unused pins..... II-4- 19 2.4 2.5 Mask option selection ...... II-4- 19 3. Architecture and memory map...... II-4- 20 3.1 Data memory bank configuration and addressing modes ....... II-4- 20 3.2 Memory mapped I/O ..... II-4- 31 4. Internal CPU function ...... II-4- 34 4.1 Program counter (PC) ...... II-4- 34 4.2 Program memory (ROM) ...... II-4- 35 4.3 Data memory (RAM) ...... II-4- 37 General purpose registers ...... II-4- 39 4.4 4.5 Accumulator ..... II-4- 40 Stack pointer (SP)...... II-4- 40 4.6 Program status word (PSW) ...... II-4- 42 4.7 4.8 Bank selection register (BS)...... II-4- 44 5. Peripheral hardware function ...... II-4- 45 Digital input/output ports...... II-4- 45 5.1 5.2 Clock generator ...... II-4- 58 5.3 Basic interval timer ..... II-4- 65 5.4 Watch timer ...... II-4- 69 Timer/event counter configuration ...... II-4- 71 5.5 Serial interface ...... II-4- 80 5.6 LCD controller driver..... II-4-106 5.7 5.8 A/D converter ...... II-4-131 5.9 Bit sequential buffer ...... II-4-136 | | | | Page | |-----|-------|---------------------------------------------------|----------| | 6. | Inter | rupt function | II-4-137 | | | 6.1 | Interrupt control circuit configuration | II-4-137 | | | 6.2 | Interrupt source types and vector table | II-4-139 | | | 6.3 | Hardware devices of interrupt control circuit | | | | 6.4 | Interrupt sequence | | | | 6.5 | Multi interrupt service control | II-4-146 | | | 6.6 | Vector address share interrupt service | II-4-146 | | | 6.7 | Machine cycles to interrupt service start | II-4-147 | | | 6.8 | Effective use of interrupt | II-4-147 | | | 6.9 | Interrupt application | II-4-148 | | 7. | Stan | dby function | II-4-153 | | ٠. | 7.1 | Standby mode setting and operating state | | | | 7.2 | Standby mode release | | | | 7.3 | Operation after standby mode is released | | | | 7.4. | Application of standby mode | | | 8. | RES | ET function | II-4-160 | | 9. | Flec | trical characteristics | II-4-162 | | ٠. | 9.1 | Package information | | | 10 | DD: | 75P328 (OTPROM) 4-bit microcomputer | 11 4 404 | | 10. | | Overview | | | | 10.1 | Features | | | | | Block diagram | | | | 10.3. | Pin configuration | | | | 10.5 | Pin functions | | | | 10.5 | Differences between μPD75P328 and μPD75328 | | | | 10.7 | One-time PROM (Program memory) write verification | | | | 10.7 | Electrical characteristics | | | | 10.9 | Package information | | | | | | | | | apter<br>OM-7 | 5<br>5X Family Standard Instruction Set | Page | |----|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------| | 1. | Feat<br>1.1<br>1.2<br>1.3<br>1.4<br>1.5 | ured instruction | II-5- 1 | | 2. | Instr | uction set and operation | II-5- 3 | | 3. | Ope | ration codes of instruction | II-5-10 | | 4. | 4.1<br>4.2<br>4.3<br>4.4<br>4.5<br>4.6<br>4.7<br>4.8<br>4.9<br>4.10<br>4.11 | Transfer instructions Table reference instructions Operating instructions Accumulator manipulation instructions Increment and decrement instructions Comparison instructions Carry flag manipulation instructions Memory bit manipulation instructions Branch instructions Subroutine stack control instructions Interrupt control instructions | II-5-14<br>II-5-14<br>II-5-18<br>II-5-19<br>II-5-20<br>II-5-20<br>II-5-21<br>II-5-23<br>II-5-24 | | | 4.11 | Input/output instructions | II-5-24<br>II-5-25 | | | 4.13<br>4.14 | CPU control instructions | II-5-26<br>II-5-26 | | | apter 6<br>v End 4-bit Microcomputer μPD75402 | Pa | age | |----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------| | 1. | Overview | II-6-<br>II-6-<br>II-6- | 1<br>2<br>2<br>3 | | 2. | Pin function | II-6-<br>II-6- | 7<br>8 | | 3. | Architecture features and memory map | 11-6- | 13 | | 4. | Internal CPU function 4.1 Program counter (PC) 4.2 Program memory (ROM) 4.3 Data memory 4.4 General purpose registers 4.5 Accumulators 4.6 Stack pointer (SP) 4.7 Program status word (PSW) | II-6-<br>II-6-<br>II-6-<br>II-6-<br>II-6- | 19<br>19<br>20<br>21<br>22<br>22 | | 5. | Peripheral hardware function | II-6-<br>II-6-<br>II-6- | 25<br>36<br>39<br>41 | | 6. | Interrupt function | II-6-<br>II-6-<br>II-6-<br>II-6- | 67<br>69<br>70<br>74<br>75 | | | | Page | |-----------|---------------------------------------|----------------------------------------------------------| | <b>7.</b> | Standby function | II-6- 81<br>II-6- 82<br>II-6- 83<br>II-6- 83 | | В. | RESET function | II-6- 84 | | 9. | Electrical characteristics | | | 10. | μPD75P402 low end 4-bit microcomputer | II-6- 98<br>II-6- 99<br>II-6-103<br>II-6-104<br>II-6-108 | | 11. | Electrical characteristics | | | 12. | Instruction set μPD75402A | II-6-124<br>II-6-125<br>II-6-130 | ### CHAPTER 1 µPD75004/006/008 STANDARD 4-BIT MICROCOMPUTER #### 1. Overview μPD75004, μPD75006 and the μPD75008 are high-speed, high-performance 4-bit single-chip microcomputers in the μCOM-75X product family. BOM size: 8064 x 8 bits (max.) · RAM size: 512 x 4 bits · General purpose registers: 4-bit x 8 · High-speed operation: Minimum instruction execution time: 1µs · Eight interrupt sources and efficient interrupt processing • Efficient instruction set which can manipulate data in 1-, 4-, or 8-bit units. · Enhanced timer function: 3 channels · Low-power clock operation in standby mode (with subsystem clock for low power dissipation operation) · Internal NEC standard serial bus interface Table 1-1 shows the program memory size for each of these products. Table 1-1 Program Memory Size for Each Product | Product | Program memory (ROM) | Remarks | |----------|----------------------|----------| | μPD75004 | 4096 x 8 bits | | | μPD75006 | 6016 x 8 bits | Mask ROM | | μPD75008 | 8064 x 8 bits | | Applications: • Consumer electronic products VCR's, audio systems (CD players, etc.), remote controllers, etc. · Other product applications telephones, cameras, etc. Remarks: This manual describes the $\mu$ PD75004, $\mu$ PD75006 and $\mu$ PD75008. The μPD7500X described here is functionally equivalent to the μPD75004, μPD75006 and μPD75008, unless stated otherwise. Therefore, except where noted, the µPD7500X is used generally to refer the µPD75004. $\mu PD75006$ and $\mu PD75008$ . #### 1.1 Features - · 41 different systemized instructions - Abundant bit manipulation instructions - Effecient 4-bit data manipulation instructions - 8-bit data transfer instructions - The GETI instruction which enables execution of an arbitrary 2-byte/3-byte instruction with 1 byte. - High-speed operation ... Minimum instruction execution time: 0.95µs/4.19MHz, 5V - · Capable of operating at low voltage and reduced power dissipation. Variable instruction execution time function - With main subsystem clock selected: 0.95us, 1.91us, 15.3us at 4.19MHz - With the subsystem clock selected: 122us at 32.768kHz - · Program memory size: μPD75004: 4096 x 8 bits (mask ROM) - μPD75006: 6016 x 8 bits (mask ROM) μPD75008: 8064 x 8 bits (mask ROM) • Data memory size (RAM): 512 x 4 bits · General purpose registers - For 4-bit manipulation: 8 registers (X, A, B, C, D, E, H, L) - For 8-bit manipulation: 4 registers (XA, BC, DE, HL) - Accumulators - Bit accumulator (CY) - 4-bit accumulator (A) - 8-bit accumulator (XA) - 34 I/O lines - Input pins: 8 - Middle voltage N-ch open drain input/output pins: 8 (can directly drive LED) - CMOS input/output pins: 18 (pins which can directly drive LED: 4 pins) - Built-in pull-up resistors can be provided for 33 I/O lines. - By means of software: 25 I/O lines - By means of mask option: 8 I/O lines - Timer: 3-ch - 8-bit timer/event counter - 4-step clock source - Capable of event count operation - 8-bit basic interval timer - Reference timer generation (1.95ms, 7.81ms, 31.3ms, 250ms at 4.19MHz) - Can be used as a watchdog timer - Clock timer - 0.5-second interval generation - Count clock sources: Can be selected from the Main system clock and subsystem clock - Clock advance mode (3.9ms interval generation) - Capable of outputting buzzer signal (2kHz) - · 8-bit serial interface - Can accomodate three different modes - Three-line serial I/O mode - Two-line serial I/O mode - SBI mode - LSB-first/MSB-first selectable - Bit sequential buffer (special bit manipulation memory of 16 bits) - Suitable for remote control applications - · Clock output functions - Timer/event counter output (PTO0): Square wave output of arbitrary frequency - Clock output (PCL): $\phi$ , $f_{\chi}/2^3$ , $f_{\chi}/2^4$ , $f_{\chi}/2^6$ - Buzzer output (BUZ): 2kHz at 4.19MHz (32.768kHz) - · Vector interrupt function - External vector interrupt sources: 3 - Both edges detection interrupt (INT4) - Detection edge programmable interrupt with noise elimination function (INT0) - Detection edge programmable interrupt (INT1) - External rising edge detection/parallel port edge detection test input (INT2) - Internal vector interrupt sources: 3 - Timer/event counter 0 interrupt (INTT0) - Basic interval timer interrupt (INTBT) - Serial interface interrupt (INTCSI) - Clock test input (INTW) - Two built-in system clock generators - Ceramic/crystal oscillator for main system clock generator: 4.194304MHz (standard) - Crystal oscillator for subsystem clock generator: 32.768kHz (standard) - Standby functions - STOP mode: The main system clock operation stops - HALT mode: The main system clock operation continues (CPU clock supply stops) - CMOS ### 1.2 Ordering Information | Order code | Package | Internal ROM | |--------------------|---------------------------|--------------| | μPD75004CU-XXX | 42-pin plastic shrink DIP | Mask ROM | | μPD75004GB-XXX-3B4 | 44-pin plastic QFP (bent) | Mask ROM | | μPD75006CU-XXX | 42-pin plastic shrink DIP | Mask ROM | | μPD75006GB-XXX-3B4 | 44-pin plastic QFP (bent) | Mask ROM | | μPD75008CU-XXX | 42-pin plastic shrink DIP | Mask ROM | | μPD75008GB-XXX-3B4 | 44-pin plastic QFP (bent) | Mask ROM | Remarks: XXX is the code number of mask ROM and option specification. ### 1.3 Functional Differences between Family Products | | Item | μPD75004CU/GB | μPD75006CU/GB μPD75008CU/G | | | | |-------------------------|----------------------------|----------------------------------------------|----------------------------------------------------|--|--|--| | Program Memory | | • Mask ROM<br>• 000H-FFFH<br>• 4096 x 8 bits | • Mask ROM<br>• 0000H-177FH<br>• 6016 x 8 bits | | | | | Data memory | | | 512 x 4 bits<br>Bank 0: 256 x 4<br>Bank 1: 256 x 4 | | | | | Instruction set | 3-byte branch instruction | None | Provided | | | | | instruction set | Other | Common | | | | | | Program counter | | 12 bits | 13 bits | | | | | Pull-up resistor | Ports 0 to 3, Ports 6 to 8 | Can be specified by software | | | | | | Pull-up resistor | Port 4, Port 5 | Mask option | | | | | | Operating voltage range | | 2.7 V - 6.0 V | | | | | | Destruction | | 42-pin plastic shrink DIP | | | | | | Package | | 44-pin plastic QFP (bent) | | | | | II-1-4 Note 1: For the µPD75004, the program is 12 bits. For the µPD75006, µPD75008 program counter size is 13 bits. ### 1.5 Pin Configuration (Top View) μPD75008 · 42-pin plastic shrink DIP • 44-pin plastic QFP | Pin name | | | | |----------|--------------|-----------------------|------------------------------------| | P00-03: | Port 0 | SO: | Serial Output | | P10-13: | Port 1 | SB0; 1 | Serial Bus 0, I | | P20-23: | Port 2 | RESET: | Reset Input | | P30-33: | Port 3 | TIO: | Timer Input 0 | | P40-43: | Port 4 | PTO0: | Programmable Timer Output 0 | | P50-53: | Port 5 | BUZ: | Buzzer Clock | | P60-63: | Port 6 | PCL: | Programmable Clock | | P70-73: | Port 7 | INTO, 1, 4: | External Vector Interrupt 0, 1, 4 | | P80-81: | Port 8 | INT2: | External Test Input 2 | | KR0-7: | Key Return | X1, X2: | Main System Clock Oscillation 1, 2 | | SCK: | Serial Clock | XT1, 2: | Subsystem Clock Oscillation 1, 2 | | SI: | Serial Input | NC/V <sub>pp</sub> *: | No Connection | <sup>\*</sup> When using OTP μPD75P008 in the same socket, please note that this pin is V<sub>PP</sub> and has to be connected to V<sub>DD</sub> in operating mode. #### 2. PIN FUNCTIONS 2.1.1 P00-P03 (PORT0) ... Also serves as INT4, SCK, SO/SB0, SI/SB1 input pins P10-P13 (PORT1) ... Also serves as INT0, INT1, INT2, TI0 input pins These pins are input pins of the 4-bit input ports: Ports 0 and Port 1. Ports 0 and 1 are input ports. However, in addition to their input function, the pins of these ports have the following functions: (1) Port 0: Vector interrupt input (INT4) Serial interface input/output (SCK, SO/SB0, SI/SBI) (2) Port 1: Vector interrupt input (INT0, INT1) Edge detection test input (INT2) Timer/event counter external event pulse input (TI0) Each pin of Ports 0 and 1 employs a Schmidt trigger input circuit to prevent malfunction due to noise, and can function as an input pin regardless of the operation of the shared pin. In addition, a noise elimination circuit is provided for P10 (refer to 6.3 (2) for details). An internal pull-up resistor can be software specified for Port 0 in 3-bit units (P01-P03), and in 4-bit units (P10-P13) for Port 1. This specification can be made by manipulating the pull-up resistor specification register group A. When the RESET signal is generated, each of these port pins is set to the input port mode. 2.1.2 P20-P23 (PORT2) ... Also serves as PTO0, PCL, BUZ input/output pins P30-P33 (PORT3) ... 3-state input/output P40-P43 (PORT4), P50-P53 (PORT5) ... N-ch open-drain middle-voltage (10V) large current output pins P60-P63 (PORT6), P70-P73 (PORT7) ... 3-state input/output Ports 2 to 7, whose pin functions are described above, are 4-bit input/output ports with output latches. The pins of Ports n (n=2, 3, 6, and 7) also have the following functions: (1) Port 2: Timer/event counter output (PTO0). Clock output (PCL). Fixed frequency output (BUZ). (2) Port 3: Input/output can be selected bitwise (3) Ports 6 and 7: Key interrupt input (KR0-KR3, KR4-KR7) Since Port 3 can output large current and Ports 4 and 5 are N-ch open-drain (middle-voltage (10V), large current output ports), these three ports can directly drive LED's. Input/output mode selection for each port is made by setting the port mode register: Ports m (m=2, 4, 5, and 7) can be specified for input/output in 4-bit units; Ports 3 and 6 can be specified for input/output in bit units. The internal pull-up resistor can be specified for Ports n in 4-bit units by software: this is done by manipulating pull-up resistor specification register group A (POGA). For Ports 4 and 5, the internal pull-up resistor can be specified in bit units by the mask option. Ports 4 and 5, and Ports 6 and 7 can be paired to enable an input/output operation in 8-bit units. When the RESET signal is generated, the output latches of these ports are cleared, Ports n are set to the input mode (high impedance output), and Ports 4 and 5 are set to a high level (when internal pull-up resistor is provided) or at high impedance. #### 2.1.3 P80-P81 (PORT8) These are input/output pins for Port 8 which is a 2-bit input/output port with an output latch. The internal pull-up resistor can be specified for Port 8 in 2-bit units by software. This specification can be made by manipulating pull-up resistor specification register group B (POGB). #### 2.1.4 TI0 ... Port 1 shared input/output This is the external event pulse pin for the programmable timer/event counter. This is Schmidt trigger input. #### 2.1.5 PTO0 ... Port 2 shared output This is the programmable timer/event counter output pin. Squarewave pulses are output from this pin. To output the programmable timer/event counter signal, the P20 output latch must be cleared to 0 and the Port 2 bit of the port mode register must be set to the output mode (1). The output is cleared to 0 when the timer start instruction is executed. #### 2.1.6 PCL ... Port 2 shared output This is the programmable clock output pin. This pin is used to supply the clock to peripheral LSI (slave microcomputer, A/D converter, etc.). When the RESET signal is generated, the clock mode register (CLOM) is cleared to 0, the clock output is disabled, and this pin functions as a normal port pin. #### 2.1.7 BUZ - Output Pin Also Used for Port 2 BUZ is a fixed frequency output pin. Fixed frequency (2.048 kHz) output is used for buzzer sounding and system clock oscillation frequency trimming. The BUZ pin, also used for the P23 pin, is validated only when bit 7 (WM7) of the watch mode register (WM) is set to 1. When the RESET signal is generated, WM7 is cleared and the normal port operation mode is set. #### 2.1.8 SCK, SO/SB0, and SI/SB1 - 3-State Input/Output Pins Also Used for Port 0 SCK, SO/SB0, and SI/SB1 are input/output pins for serial interface and operate according to how the serial operation mode register (CSIM) is set. When the RESET signal is generated, serial interface operation is stopped and the pins are used for port 0 (input port). Every pin is Schmitt trigger input. #### 2.1.9 INT4 - Input Pin also Used for Port 0. INT4 is an external vectored interrupt input pin (both rising and falling edged active). When the signal input to the pin changes from low to high state or from high to low state, the interrupt request flag is set. INT4 is for asynchronous input. When a signal having a given high or low level duration is input, it is acknowledged independently of the CPU operation clock. INT4 can also be used to release the STOP or HALT mode. It is Schmitt trigger input. #### 2.1.10 INT0 and INT1 - Input Pins Also Used for Port 1 INT0 and INT1 are edge detection vectored interrupt input pins. INT0 has the noise removal function. Detected edge selection can be made using edge detection mode registers (IM0 and IM1). - (1) INTO (IMO bits 0 and 1) - (a) Rising edge active - (b) Falling edge active - (c) Both rising and falling edges active - (d) External interrupt signal input inhibited - (2) INT1 (IM1 bit 0) - (a) Rising edge active - (b) Falling edge active INTO has the noise removal function; sampling clocks for noise removal can be changed two stages. The acknowledged signal width varies depending on CPU clock operation. INT1 is for asynchronous input. When a signal having a given high level duration is input, it is acknowledged independently of the CPU clock operation. When the RESET signal is generated, IM0 and IM1 are cleared and rising edge active is selected. INTO and INT1 are Schmitt trigger inputs. #### 2.1.11 INT2 - Input Pin Also Used for Port 1 INT2 is an external test input pin (both rising and falling edges active). When INT2 is selected by using the edge detection mode register (IM2) and the signal input to the INT2 pin transits from low to high state, the internal test flag (IRQ2) is set. INT2 is for asynchronous input. When a signal having a given high level duration is input, it is acknowledged independently of the CPU clock operation. When the RESET signal is generated, IM2 is cleared and the test flag (IRQ2) is set by inputting the rising edge to the INT2 pin. ### 2.1.12 KR0-KR3 - Input Pins Also Used for Port 6 KR4-KR7 - Input Pins Also Used for Port 7 KR0-KR7 are key interrupt (parallel falling edge detection interrupt) input pins. The interrupt format can be specified by setting the edge detection mode register (IM2). When the RESET signal is generated, the pins are placed in port 6 and 7 input mode. #### 2.1.13 X1 and X2 X1 and X2 are connection pins for the main system clock crystal / ceramic oscillator. External clocks can also be input. ### 2.1.14 XT1 and XT2 XT1 and XT2 are crystal connection pins for the subsystem clock oscillation. External clocks can also be input. ### 2.1.15 RESET RESET is an active low reset input pin. RESET is for asynchronous input. When a signal having a given low level duration is input independently of the operation clock, the RESET signal is generated and the system is reset overriding all other operations. It is used for normal CPU initialization / start-up and also to release the standby (STOP or HALT) mode. RESET is a Schnitt trigger input. ### 2.1.16 V<sub>DD</sub> V<sub>DD</sub> is a positive power supply pin. ### 2.1.17 V<sub>ss</sub> V<sub>ss</sub> is a ground potential. #### 2.2 Pin Function List (1) Normal operation mode Table 2.2-1 Digital Input / Output Port Pin Function List | Pin name | 1/0 | Also<br>used for: | Fur | Function | | When reset | I/O circuit<br>type (Note 1) | |---------------------|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------|------------------------------| | P00 | 1 | INT4 | 4-bit input port (port 0). | | | Input | B | | P01 | 1/0 | SCK | Internal pull-up r | Internal pull-up resistors | | | _ А | | P02 | 1/0 | SO/SBO | can be specified in 3-bit units by | | | IIIput | (F)- В | | P03 | 1/0 | SI/SB1 | in o on dring by | domg domaid | | | <b>M</b> −c | | P10 | | INTO | | With noise removal function | | | 1000 | | P11 | 1 | INT1 | 4-bit input port ( | | × | Input | (B)- C | | P12 | | INT2 | Internal pull-up of can be specified | | | | | | P13 | | TIO | in 4-bit units by | | | | | | P20 | | PTOO | 4-bit input/outpu | it port (port 2) | | | | | P21 | ] ,, | - | Internal pull-up | resistor can be | x | Input | E D | | P22 | 1/0 | PCL | specified for P20<br>units by using so | | _ ^ | mput | E – B | | P23 | | BUZ | units by using s | onware. | | | | | P30 | | _ | | Programmable 4-bit input/output | | | | | P31 | ] | _ | port (port 3). Input or output mode can be selected bitwise. | | | | | | P32 | 1/0 | | Internal pull-up | | X | Input | E – B | | P33 | ] | _ | specified for P30-P33 in 4-bit<br>units by using software. (Note 2) | | | | | | P40-P43<br>(Note 2) | 1/0 | <del>-</del> | N-channel open drain 4-bit input/output port (port 4). Pull-up resistor can be incorporated bitwise (mask option). 10 Volts during open drain. | | 0 | High level (when<br>pull-up resistor<br>is incorporated)<br>or high<br>impendance | М | | P50-P53<br>(Note 2) | 1/0 | _ | input/output por<br>Pull-up resistor<br>incorporated bit<br>option). | N-channel open drain 4-bit input/output port (port 4). Pull-up resistor can be incorporated bitwise (mask option). 10 Volts during open drain. | | High level (when pull-up resistor is incorporated) or high impendance | М | | P60 | | KR0 | | 4-bit input/output<br>out or output mode | | | | | P61 | ] ,,, | KR1 | can be selected | | | Innut | (F) A | | P62 | 1/0 | KR2 | | Internal pull-up resistor can be specified for P60-P63 in 4-bit units by using software. | | Input | (F)- A | | P63 | 1 | KR3 | | | | | - | | P70 | | KR4 | 4 5 5 5 5 5 5 5 | A = - + ( + 7) | 1 | | | | P71 | | KR5 | | 4-bit input/output port (port 7). Internal pull-up resistor can be | | Input | | | P72 | 1/0 | KR6 | specified for P70-P73 in 4-bit | | | | (F)- A | | P73 | | KR7 | units by using s | units by using software. | | | * | (to be continued) Table 2.2-1 Digital Input / Output Port Pin Function List (cont`d) | F | Pin name | 1/0 | Also<br>used for | Function | 8-bit<br>I/O | When reset | I/O circuit<br>type (Note 1) | |---|----------|--------|------------------|-----------------------------------------------------------------------|--------------|------------|------------------------------| | | P80 | Input/ | | 2-bit input/output port (PORT8).<br>Built-in pull-up resistors can be | Y | Input | E-B | | | P81 | Output | | specified in 2-bit units by software. | ^ | mput | | Note 1: The O mark denotes Schmitt trigger input Note 2: LED can be driven directly Table 2.2-2 Pin Function List other than Port Pins | Pin name | Tubic Lie Li | | tion List othe | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|----------------|-----------------------------------------|------------------------------------------------------------|--------|---------------------| | PT00 I/O P20 Timer / event counter output pin. Input E − B PCL I/O P22 Clock output pin. Input E − B BUZ I/O P23 Fixed frequency output pin (for buzzer or system clock trimming). Input E − B SCK I/O P01 Serial data output pin. Input ♠ − A SO/SB0 I/O P02 Serial data output pin. Input ♠ − A SI/SB1 I/O P03 Serial data input pin. Serial bus input / output pin. Input ♠ − C INT4 I P00 Edge detection vectored interrupt input pin (detection of both rising and falling edges is active). ♠ B INT1 P10 Edge detection vectored interrupt input pin (detection selected). Asynchronous ♠ − C INT2 I P12 Edge detection testable input pin asynchronous (rising edge is detected). ♠ − C KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. Input ♠ − A XR4-KR7 I/O P70-P73 Parallel f | Pin name | 1/0 | | Function | | | | | PCL I/O P22 Clock output pin. Input E - B BUZ I/O P23 Fixed frequency output pin (for buzzer or system clock trimming). SCK I/O P01 Serial clock input / output pin. Input P- A SO/SB0 I/O P02 Serial data output pin. Input P- B SI/SB1 I/O P03 Serial data input pin. Input P- B SI/SB1 I/O P03 Serial data input pin. Input P- B SI/SB1 I/O P03 Serial data input pin. Input P- B SI/SB1 I/O P03 Serial data input pin. Input P- B SI/SB1 I/O P03 Serial data input pin. Input P- C pin asynchronous (rising edge is detected). Synchronous P- Colock Asynchronous (rising edge is detected). B- C KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. Input P- A KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output Input P- A X1, X2 - Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 AT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to X1 AT2 - Connection Pins for main system clock orystal connection pins. When external clock is used, it is input to X1 AT2 - Connection Pins for main system clock orystal connection pins. When external clock is used, it is input to X1 AT2 - Connect | TIO | 1 | P13 | External event pulse input pin to time | r / event counter. | | <b>B</b> −c | | BUZ I/O P23 Fixed frequency output pin (for buzzer or system clock trimming). SCK I/O P01 Serial clock input / output pin. SO/SB0 I/O P02 Serial data output pin. Serial bus input / output pin. Serial bus input / output pin. Serial bus input / output pin. Serial bus input / output pin. Serial bus input / output pin. INT4 I P00 Edge detection vectored interrupt input pin (detection of both rising and falling edges is active). INT0 I P11 Edge detection vectored interrupt input pin (detection of both rising and falling edges is active). INT1 I P12 Edge detection vectored interrupt input pin (detection of both rising and falling edges is active). INT2 I P12 Edge detection vectored interrupt input pin asynchronous (rising edge is detected). KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output pins. Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to X1, and XT2 is not connected. XT1 can be used for 1-bit input NC (Note 2) - No connection B No connection positive power supply pin | PT00 | 1/0 | P20 | Timer / event counter output pin. | | Input | E-B | | SCK I/O P01 Serial clock input / output pin. Input P-A | PCL | I/O | P22 | Clock output pin. | - | Input | E-B | | SO/SB0 I/O P02 Serial data output pin. Serial bus input / output pin. Serial bus input / output pin. Input P-B SI/SB1 I/O P03 Serial data input pin. Serial data input pin. Serial data input pin. Input M-C INT4 I P00 Edge detection vectored interrupt input pin (detection of both rising and falling edges is active). INT0 P10 Edge detection vectored interrupt input pin (detection of both rising and falling edges is active). INT1 I P12 Edge detection vectored interrupt input pin (detected edge can be selected). KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output pins. X1, X2 - Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin. No connection No connection Positive power supply pin. Input F-A Input F-A Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin. Reset I System reset input pin. No connection Positive power supply pin. | BUZ | 1/0 | P23 | | r or system clock | Input | E-B | | Sci Si | SCK | I/O | P01 | Serial clock input / output pin. | | Input | (F)- A | | Serial bus input / output pin. NT4 | SO/SB0 | 1/0 | P02 | | - | Input | ( <del>Г</del> )– В | | INT0 I P10 Edge detection vectored interrupt input pin (detected edge can be selected). INT1 P11 Edge detection vectored interrupt input pin (detected edge can be selected). INT2 I P12 Edge detection testable input pin asynchronous (rising edge is detected). KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output pins. Input F-A X1, X2 Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin. Positive power supply pin. - Connection pins for main system clock crystal/ceramic oscillation crystal connection pins. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input — — — — — — — — — — — — — — — — — — — | SI/SB1 | 1/0 | P03 | | | Input | <b>M</b> -c | | INTO INT1 P10 Clock input pin (detected edge can be selected). INT2 I P12 Edge detection testable input pin asynchronous (rising edge is detected). KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output pins. Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin. P12 Edge detection testable input / output pin asynchronous (rising edge clock crystal/ceramic oscillation testable input / output pinut / output pinut (E)—A Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin. RESET I System reset input pin. No connection — — — — — — — — — — — — — — — — — — — | INT4 | ı | P00 | | | | B | | INT1 P11 selected). Asynchronous INT2 I P12 Edge detection testable input pin asynchronous (rising edge is detected). KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output pins. Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin. NC (Note 2) - Positive power supply pin. - Asynchronous B-C | INT0 | | P10 | Lage detection vectored interrupt | | | ®- c | | KR0-KR3 I/O P60-P63 Parallel falling edge detection testable input / output pins. Input F-A | INT1 | | P11 | | Asynchronous | | | | KR0-KR3 I/O P60-P63 pins. Input FA Parallel falling edge detection testable input / output pins. KR4-KR7 I/O P70-P73 Parallel falling edge detection testable input / output pins. Connection pins for main system clock crystal/ceramic oscillator. When external clock is used, it is input to X1 and its opposite phase is input to X2. XT1 I Subsystem clock oscillation crystal connection pins. When external clock is used, it is input to XT1, and XT2 is not connected. XT1 can be used for 1-bit input (test) pin. RESET I System reset input pin B NC (Note 2) - No connection | INT2 | ı | P12 | | | | <b>®</b> −c | | X1, X2 | KR0-KR3 | I/O | P60-P63 | | | Input | (F)- A | | X1, X2 | KR4-KR7 | I/O | P70-P73 | | Input | (Ē)- A | | | XT2 - | X1, X2 | | <u>-</u> | oscillator. When external clock is use | oscillator. When external clock is used, it is input to X1 | | | | XT2 - (test) pin. - - - - B RESET I System reset input pin. - - B NC<br>(Note 2) - No connection - - - V <sub>DD</sub> - Positive power supply pin. - - - | XT1 | ı | | When external clock is used, it is inpu | | | | | NC (Note 2) - No connection - - V <sub>DD</sub> - Positive power supply pin. - - | XT2 | - | ~ | | _ | _ | | | (Note 2) No connection - - V <sub>DD</sub> - Positive power supply pin. - - | RESET | ı | | System reset input pin. | | - | B | | | | _ | | No connection | | _ | _ | | V <sub>SS</sub> – Ground potential pin. – – | V <sub>DD</sub> | _ | | Positive power supply pin. | | - | - | | | V <sub>ss</sub> | - | | Ground potential pin. | | - | _ | Notes: 1.The mark denotes Schmitt trigger input. <sup>2.</sup> Connected the NC pin to $V_{DD}$ , when $\mu PD75P008$ and printed board are also shared with. ### 2.3 Pin Input / Output Circuits The $\mu PD7500X$ pin input / output circuits are shown in schematic drawings. (1) Type A (for Type E - B) CMOS standard input buffer (2) Type B Schmitt trigger input with hysteresis characteristic (3) Type B - C P.U.R.: Pull-Up Resistor (4) Type D (for Type E - B, F - A) Push-pull output where output can be placed in high impedance (both P and N channels are turned off). (5) Type E - B (6) Type F - A P.U.R.: Pull-Up Resistor ### (7) Type F - B P.U.R.: Pull-Up Resistor ### (8) Type M P.U.R.: Pull-Up Resistor ### (9) Type M - C P.U.R.: Pull-Up Resistor ### 2.4 Processing of Unused Pins ### Table 2.4-1 Unused Pins Lists | Pin | Recommended connection | |-----------------------|-------------------------------------------------------------------------------------------| | P00 / INT4 | Connect to V <sub>SS</sub> . | | P01 / SCK | | | P02 / SO /SB0 | Connect to V <sub>SS</sub> or V <sub>DD</sub> . | | P03 / SI / SB1 | | | P10 / INTO-P12 / INT2 | Connect to V | | P13 / TI0 | Connect to V <sub>SS</sub> . | | P20 / PTO0 | | | P21 | | | P22 / PCL | | | P23 / BUZ | | | P30-P33 | Input mode: Connect to V <sub>SS</sub> or V <sub>DD</sub> . Output mode: Do not connect. | | P40-P43 | Output mode. Do not connect. | | P50-P53 | | | P60-P63 | · | | P70-P73 | | | P80-P81 | | | XT1 | Connect XT1 to V <sub>SS</sub> or V <sub>DD</sub> . | | XT2 | Do not connect XT2. | ### 2.5 Mask Option Selection The pins contain the mask option function as listed in Table 2.5-1. However, mask option is not contained in the $\mu\text{PD75P008}.$ Table 2.5-1 Mask option selection | Pin names | Mask option | |---------------------|-------------------------------------------------------------------------------------------| | P40-P43,<br>P50-P53 | Pull-up resistor is included.<br>specified bit-wise.<br>Pull-up resistor is not included. | ### 3. ARCHITECTURE AND MEMORY MAP The $\mu$ COM-75X architecture for the $\mu$ PD7500X adopts data memory bank configuration and memory mapped I / O to provide features such as: - Internal RAM with maximum of 4K words x four bits (12-bit addresses) - Peripheral hardware extensibility This chapter covers these topics. #### 3.1 Data Memory Bank Configuration and Addressing Modes #### 3.1.1 Data memory bank configuration A general purpose static RAM (512 words x four bits) is incorporated in data memory space addresses 000H to 1FFH. Peripheral hardware such as input/output ports and timers is allocated to addresses F80H to FFFH. To address the data memory space (4K words x four bits) with 12-bit addresses, the µPD7500X adopts a memory bank configuration where the low-order eight bits of an address are specified either directly or indirectly by using an instruction, and the high-order four bits of an address are specified by using a memory bank. To specify the memory bank (MB), two hardware devices are incorporated in the µPD7500X: - Memory bank enable flag (MBE) - Memory bank selection register (MBS) MBS is a register used to select a memory bank. The µPD7500X allows 0, 1, or 15 to be set in MBS. MBE is a flag used to determine whether or not the memory bank selected by using MBS is validated. As shown in Fig. 3.1–1, when MBE is set to 0, the specified memory bank is fixed regardless of how MBS is set; when MBE is set to 1, memory bank switching can be performed to extend data memory space by setting MBS. In data memory space addressing, normally MBE is set to 1, and the data memory area of the memory bank specified by using MBS is handled. An efficient program can be prepared by using MBE = 0 mode and MBE = 1 mode appropriately in each process of the program. | | Applicable program processing | Effects | |--------------|------------------------------------------------------------------------------------------------|--------------------------------------------| | | ° Interrupt service | MBS save and restore are made unnecessary. | | MBE = 0 mode | ° Repetitive processing of internal<br>hardware operation and general<br>purpose RAM operation | MBS change is made unecessary. | | · | ° Subroutine processing | MBS save and restore are made unnecessary. | | MBE = 1 mode | ° Normal program processing | | Figure 3.1-1: Proper Use of MBE = 0 and MBE = 1 Modes MBE is saved or restored automatically during subroutine processing and can be changed as desired. When interrupt service is made, MBE is automatically saved or restored. MBE during interrupt service can also be specified at the same time interrupt service starts by setting the interrupt vector table. Thus, it is useful for high-speed interrupt service. To change the MBS setting in subroutine processing or interrupt service, MBS is saved and restored by using PUSH and POP instructions. MBE is set and reset by using SET1 and CLR1 instructions. MBS is set by using the SEL instruction. Example 1: To clear MBE and fix memory bank CLR1 MBE ; MBE ◆ 0 Example 2: To select memory bank 1 SET1 MBE; MBE ← 1 SEL MB1; MBS ← 1 ### 3.1.2 Data memory addressing modes The µCOM-75X architecture adopted for the µPD7500X provides seven addressing modes, as shown in Fig. 3.1–2, for efficiently addressing the data memory space for each bit length of data to be processed. ### (1) 1-bit direct adressing (mem. bit) This addressing mode directly specifies each bit in all the data memory space by using the instruction operand. When MBE is set to 0, the specified memory bank (MB) is fixed to memory bank 0 (MB0) if the address specified in the operand is 00H-7FH; it is fixed to memory bank 15 (MB15) if the address specified in the operand is 80H-FFH. Thus, when MBE is set to 0, both the general purpose RAM area (000H-07FH) and peripheral hardware area (F80H-FFFH) can be addressed. When MBE is set to 1, any memory bank can be specified by setting MBS; data memory space that can be specified can be extended. The 1-bit direct addressing mode is applicable to bit set and reset instructions (SET1 and CLR1) and bit test instructions (SKT and SKF). ### Example: To set FLAG1, reset FLAG2, and test whether or not FLAG3 is set to 0. | FLAG1<br>FLAG2 | EQU<br>EQU | 03FH. 1<br>087H. 2 | ; | 3FH address bit 1<br>87H address bit 2 | |----------------|------------|--------------------|---|----------------------------------------| | | | | , | | | FLAG3 | EQU | 0A7H. 0 | ; | A7H address bit 0 | | | SET1 | MBE | ; | MBE ◆ 1 | | | SEL | MB0 | ; | MBS | | | SET1 | FLAG1 | ; | FLAG1 - 1 | | | CLR1 | FLAG2 | ; | FLAG2 0 | | | SKF | FLAG3 | ; | FLAG3 = 0? | Figure 3.1-2 Data Memory Configuration and Addressing Range of each Addressing Mode | Addressing mode | Representation format | Specified address | | | |------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 1-bit direct<br>addressing | mem. bit | Bit indicated by a bit at the address indicated by MB and mem. However, MBE = 0, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FFH When MBE = 1, MB = MBS | | | | 4-bit direct addressing | | Address indicated by MB and mem. However, MBE = 0, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FH When MBE = 1, MB = MBS | | | | 8-bit direct<br>addressing | mem | Address indicated by MB and mem (mem is an even address). However, MBE = 0, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FFH When MBE = 1, MB = MBS | | | | | @ HL | Address indicated by MB and HL. However, MB = MBE • MBS | | | | 4-bit register indirect addressing | @ DE | Memory bank 0 address indicated by DE | | | | | @ DL | Memory bank 0 address indicated by DL | | | | 8-bit register indirect addressing | @ HL | Address indicated by MB and HL (the L register contains an even number). However, MB = MBE • MBS | | | | | fmem. bit | Bit indicated by a bit at the address indicated by fmem. However, fmem { FB0H-FBFH (hardware related to interrupt) FF0H-FFFH (I/O port) | | | | Bit manipulation addressing | pmem. @ L | Bit indicated by the low-order two bits of the L register at the address indicated by the high-order 10 bits of pmem and the high-order two bits of the L register. However, pmem = FC0H-FFFH | | | | | @ H + mem. bit | Bit indicated by a bit at the address indicated by MB, H, and the low-order four bits of mem. However, MB = MBE • MBS | | | | Stack addressing | | Memory bank 0 address indicated by SP. | | | Figure 3.1-3 Addressing Modes #### (2) 4-bit direct addressing (mem) This addressing mode directly specifies all the data memory space in 4-bit units by using the instruction operand. As with the 1-bit direct addressing mode, when MBE is set to 0, the 4-bit direct address mode allows that only the general purpose RAM area (000H-07FH) and peripherial hardware area (F80H-FFFH) can be specified. When MBE is set to 1, any memory bank (MB) can be specified by setting MBS and the data memory space that can be specified is extended to all the space. The 4-bit direct addressing mode is applicable to the MOV, XCH, INCS, IN, and OUT instructions. Example 1: To input port 4 and store in "DATA1". DATA1 EQU 5FH ; "DATA1" is address 5FH. CLR1 MBE ; MBE ← 0 IN A, PORT4 ; A ← PORT4 MOV DATA1, A ; (DATA1) ← A Example 2: To output data in "BUFF" to port 5. BUFF EQU 11AH "BUFF" is address 11AH MBE<del>▼</del> 1 SET1 MBE SEL MB1 MBS<del>▼</del> 1 MOV A. BUFF A← (BUFF) SEL MB15 MBS<del> </del> 15 OUT PORT5, A ; PORT5<del><</del> A #### Caution: If data related to the input /output ports is stored in general purpose RAM of bank 1 as in this example, the program is made less efficient. If data related to the input /output ports is stored in addresses 00H-7FH of bank 0, a program can be prepared without changing MBS as in Example 1. #### (3) 8-bit direct addressing (mem) This addressing mode directly specifies all the data memory space in 8 bit units by using the instruction operand. Only even address can be specified in the mem operand. The 4-bit data at the address specified in the operand and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register pair) for 8-bit processing. The memory banks specified in the addressing mode are the same as in the 4-bit direct addressing mode. The 8-bit direct addressing mode is applicable to the MOV, XCH, IN, and OUT instructions. Example 1: To transfer 8-bit data in ports 4 and 5 to addresses 20H and 21H. DATA EQU 020H CLR1 MBE ; MBE ← 0 IN XA, PORT4 ; X← port 5, A← port 4 MOV DATA, XA ; (21H) ← X, (20H) ← A Example 2: To read 8-bit data input to the serial interface shift register (SIO), set transfer data, and start of transfer. SEL MB15 ; MBS → 15 XCH XA, SIO ; XA → (SIO) #### (4) 4-bit register indirect addressing (@rpa) This addressing mode indirectly specifies the data memory space in 4-bit units by using the data pointer (general purpose register pair) specified in the instruction operand. The data pointers are the HL register pair, which enables all the data memory space to be specified according to MB = MBE • MBS specification, and the DE and DL register pairs, which always indicate memory bank 0 regardless of how MBE and MBS are set. Efficient programs can be prepared by using the data memory bank to be used. Example: To transfer data at 50H-57H to 110H-117H. ``` DATA1 EQU 57H DATA2 EQU 117H SFT1 MRF SEL MB<sub>1</sub> MOV D. #DATA1 SHR 4 MOV HL, #DATA2 AND 0FFH; HL 17H LOOP: MOV A, @DL XCH A, @HL A<del></del> (HL) DECS : L ← L-1 BR LOOP ``` The addressing mode using the HL register pair for the data pointer has wide applications such as data transfer, operation, comparison, and input / output. The addressing mode using the DE or DL register pair is applicable to the MOV and XCH instructions. As shown in Fig. 3.1–4, data memory space addresses can be updated as desired by combining the addressing mode with general purpose register (or register pair) increment and decrement instructions. Example 1: To compare data at 50H-57H with data at 110H-117H. ``` DATA1 EQU 57H DATA2 FOU 117H SFT1 MBF MR1 SEL MOV D, #DATA1 SHR 4 HL, #DATA2 AND 0FFH MOV LOOP: MOV A. @DL SKE A, @HL A = (HL)? BR NO NO DECS L YES, L← L-1 BR LOOP ``` Example 2: To clear data memory area 04H-FFH. ``` SEL MBO MOV XA. #00H MOV L. #04H LOOP: MOV @HL, A (HL) ← A INCS LOOP BR INCS н H<del><--</del> H+1 BR LOOP ``` Figure 3.1-4 General Purpose RAM Address Update Method #### (5) 8-bit register indirect addressing (@HL) This addressing mode indirectly specifies all the data memory space in 8-bit units by using the data pointer (HL register pair). The 4-bit data at the address setting data pointer bit 0 (L register bit 0) to 0 and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register) for 8-bit processing. The memory banks specified in the addressing mode are the same as those when the HL register is specified in the 4-bit register indirect addressing mode (MB = MBE • MBS). The 8-bit register indirect addressing mode is applicable to the MOV, XCH, and SKE Instructions. Example 1: To compare the count register (T0) value of timer / event counter 0 with data at addresses 30H and 31H for equality. ``` DATA EQU 30H CLR<sub>1</sub> MBF MOV HL. #DATA MOV XA, TO XA ← count register 0 SKE A. @HL A = (HL)? BR NO INCS MOV A, X Δ← Χ SKF A = (HL)? A. @HL ``` ### (6) Bit manipulation addressing This addressing mode is used to perform bit manipulations such as Boolean operation or bit transfer on any bit in all of the data memory space. Although the 1-bit direct addressing mode is applicable only to the bit set, reset, and test instructions, the bit manipulation addressing mode enables bit manipulations such as Boolean operations by using the AND1, OR1, and XOR1 instructions and allows bit test and bit reset by using the SKTCLR instructions. The following three types of bit manipulation addressing modes can be used according to the data memory address to be used: (a) Specific address bit direct addressing (fmem. bit). This addressing mode enables, peripheral hardware that frequently uses bit manipulation, such as input / output ports and interrupt flags, to be operated at any time independently of the memory bank setting. Thus, the addressing mode is applicable to data memory addresses FF0H-FFFH (where input / output ports are mapped) and FB0H-FBFH (where hardware related to interrupts is mapped). For the hardware of the two data memory areas, bit manipulation can be performed in direct addressing at any time as desired regardless of how MBS and MBE are set. Example 1: To test the timer 0 interrupt request flag (IRQT0); if the request flag is set, clear the flag and reset P63. Example 2: To reset P53 if both P30 and P41 are set to 1. (b) Specific address bit register indirect addressing (pmem. @L). This addressing mode indirectly specifies each bit of peripheral hardware, such as an input / output port, by using the L register for successive operation. The addressing mode is applicable to data memory addresses FC0H-FFFH. The addressing mode directly specifies the high-order 10 bits of a 12-bit data memory address in the pmem operand and indirectly specifies the low-order 2-bit data memory address by using the L register. Thus, 16 bits (four ports) can be manipulated (operated) successively by L register specification. The address mode also enable bit manipulation to be performed at any time independently of how MBE and MBS are set. Example: To output a pulse to each bit of ports 4 to 7 in order. (c) Special 1-bit direct addressing (@H + mem. bit) This addressing mode enables bit manipulation to be performed on any bit in all of the data memory space. The addressing mode indirectly specifies the high-order four bits of data memory address of the memory bank specified by MB = MBE MBS by using the H register and directly specifies the low-order 4-bit data memory address part and the bit address in the operands. It enable various types of bit manipulation to be performed on any bit in all of the data memory space. Example: To reset address 32H bit 2 (FLAG3) if both address 30H bit 3 (FLAG1) and address 31H bit 0 (FLAG2) are set to 0 or 1. ``` FLAG1 EQU 30H.3 FLAG2 EQU 31H.0 FLAG3 EQU 32H.2 SEL MBO MOV H. #FLAG1 SHR 6 CLR1 CY OR1 CY, @H + FLAG1 CY \leftarrow 0 XOR1 CY, @H + FLAG2 ; CY-FLAG1 SET1 CY-FLAG2 @H + FLAG3 SKT CY = 1 ? CY CLR1 @H + FLAG3 ``` ### (7) Stack addressing The stack addressing mode is used for register save and restore during interrupt service or subroutine processing. The processing mode specifies an address by using the 8-bit stack pointer (data memory bank 0). The addressing mode can also be used for register save and restore by executing the PUSH and POP instructions. Example 1: To save and restore register in subroutine processing. Example 2: To transfer the HL register pair contents to the DE register pair. PUSH HL POP DE ; DE← HL Example 3: To branch to the address indicated by [XABC] register. PUSH BC PUSH XA RET ; Branch to XABC address ## 3.2 Memory Mapped I / O The $\mu$ PD7500X adopts memory mapped I/O where peripheral hardware such as input/ports and timers is allocated to addresses F80H-FFFH of the data memory space as shown in Fig. 3.1–2. Thus, peripheral hardware is controlled entirely by memory operation instructions rather than special instructions. (To easily understand programs, some hardware control mnemonics are provided.) Table 3.2-1 lists the addressing modes that can be used to operate peripheral hardware. Table 3.2-1 Applicable Addressing Modes during Peripheral Hardware Operation | | Applicable addressing mode | Applicable hardware | | | |---------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|--| | | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem. bit). | All hardware where bit manipulation can be performed. | | | | Bit<br>manipulation | Direct addressing regardless of how MBE and MBS are set. (specification in fmem. bit) | ISTO, MBE<br>IExxx, IRQxxx, PORTn.x | | | | · | Indirect addressing regardless of how MBE and MBS are set. (specification in pmem. @L) | BSBn.x<br>PORTn.x | | | | 4-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem). | All hardware where 4-bit manipulation can be performed. | | | | manipulation | With (MBE=1 and MBS=15), register indirect addressing (specification in @HL). | | | | | 8-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem), mem must be an even address. | All hardware where 8-bit manipulation can | | | | manipulation | With MBE=1 and MBS=15, register indirect addressing (specification in @HL; the L register must contain an even number. | be performed. | | | Example: CLR1 MBE ; MBE = 0 SET1 TM0.3 ; Timer 0 starts. EI IE0 ; INT0 is enabled. DI IE1 ; INT1 is disabled. SKTCLR IRQ2 : INT2 request flag is tested and cleared. SET1 PORT4. @L; Port 4 is set. IN A, PORT0; A ← port 0 OUT PORT4, XA; Port 5, 4 ← XA Figs. 3.2-1 to 3.2-3 shows the $\mu$ PD7500X I/O map. The columns in the figures mean: ### · Abbreviation: Name indicating internal hardware address. It can be entered in the instruction operand field. ## • R/W Indicates whether the hardware device can be read or written. R/W: Read and write are enabled. R: Read only is enabled. W: Write only is enabled. ## · Number of bits that can be manipulated: Indicates the number of bits that can be processed when the hardware device is operated. - O: Bit manipulation is enabled in 1-4, 4-, or 8-bit units as specified in the column. - Δ: Only some bits can be manipulated. See Remarks for the bits that can be manipulated. - -: Bit manipulation cannot be performed in 1-, 4-, or 8-bit units as specified in the column. #### · Bit manipulation addressing: Indicates the applicable bit manipulation addressing for performing bit manipulation on the hardware device. | Address | Hardv | vare name | e (abbrev | iation) | R/W | | er of bit<br>e manip | | Bit manipulation | Remarks | |------------|-------------------------------------------|---------------------|-------------|-----------------------------------------------|---------------|--------------|----------------------|--------------|--------------------------------------------------|--------------------------------------------------| | / tadi ooo | b3 | b2 | b1 | ь0 | 1000 | One<br>bit | Four<br>bit | Eight<br>bit | addressing | Tomano | | F80H | Stack po | inter (SP | | R/W | _ | - | 0 | | Bit 0 is fixed to 0. | | | F85H | Basic int<br>register | erval time<br>(BTM) | er mode | | w | Δ | 0 | - | mem. bit | Bit manipulation can be performed only on bit 3. | | F86 H | Basic int | erval time | er (BT) | | R | - | - | 0 | | | | F98H | Watch n | node regi | ster (WM | | R/W | Δ | | 0 | mem. bit | Bit test can be made only on bit 3. | | | | | | | W | - | - | | | | | FA0H | Timer/event counter 0 mode register (TM0) | | | w | Δ | _ | 0 | mem. bit | Bit manipulation can be performed only on bit 3. | | | | , register ( ·····e) | | | | | | | | | | | FA2H | TOE0<br>(Note) | | | | w | 0 | - | _ | mem. bit | | | FA4H | Timer/e | | iter 0 cou | nt | R | | - | 0 | | | | FA6H | Timer/e | · · · | iter 0 mod | fulo | w | | - | 0 | | | | | | ` | | | <del> </del> | | | | | | | FB0H | 0 | IST0 | MBE (DC) | 0 | R/W | 0 | 0 | 0 | | | | | Program | status w | ord (PSW | <u>, , , , , , , , , , , , , , , , , , , </u> | R | | | ļ | | | | FB2H | (IME) | | | | - | - | | _ | fmem. bit EI and DI instructions are used | | | FB3H | Processor clock control register (PCC) | | | w | _ | 0 | | | | | | FB4H | INT0 mc | de regist | er (IM0) | | W | - | 0 | | | Bit 2 is fixed to 0. | | FB5H | INT1 mc | de regist | er (IM1) | | w | _ | 0 | - | | Bit 3 to 1 are fixed to 0. | | FB6H | INT2 mo | de regist | er (IM2) | | w | <del> </del> | 0 | | | Bits 3 and 2 are fixed to 0. | | FB7H | System | clock con | trol regist | er (SCC) | w | 0 | - | _ | | Only bits 3 and 0 can be bit manipulated | Note: TOE0 = timer / event counter 0 output enable flag (W) (to be continued) Figure 3.2-1 μPD7500X I/O Map | Address | Hardv | vare name | e (abbrevi | ation) | R/W | | ber of bit<br>e manip | | Bit manipulation | Remarks | |---------|--------------------------------------------------------|--------------|-------------|------------|---------------|------------|-----------------------|--------------|------------------|-----------------------| | Addicas | b3 | b2 | b1 | b0 | n/ <b>v</b> v | One<br>bit | Four<br>bit | Eight<br>bit | addressing | Tiomarks | | FB8H | IE4 | IRQ4 | IEBT | IRQBT | R/W | 0 | 0 | | | | | FBAH | | | IEW | IRQW | R/W | 0 | 0 | | | | | FBCH | | | IET0 | IRQT0 | R/W | 0 | 0 | | fmem, bit | | | FBDH | | | IECSI | IRQCSI | R/W | 0 | 0 | | imem. oit | | | FBEH | IE1 | IRQ1 | IE0 | IRQ0 | R/W | 0 | 0 | | | | | FBFH | | | IE2 | IRQ2 | R/W | 0 | 0 | _ | | | | FC0H | Bit sequ | ential buff | er 0 (BSE | 30) | R/W | 0 | 0 | ( | | | | FC1H | Bit sequ | ential buff | er 1 (BSE | 31) | R/W | 0 | 0 | 0 | mem. bit | | | FC2H | Bit sequ | ential buff | er 2 (BSE | 32) | R/W | 0 | 0 | | pmem @L | | | FC3H | Bit sequ | ential buff | er 3 (BSE | 33) | R/W | 0 | 0 | 0 | | | | FD0H | Clock ou | tput mod | e register | (CLOM) | w | _ | 0 | - | | · | | FDCH | Pull-up i | resistor so | ecification | n | | | | _ | | | | | Pull-up resistor specification register group A (POGA) | | | W | - | _ | 0 | | | | | FDEH | Pull-up resistor specification register group B (POGB) | | | w | - | - | 0 | | | | | FE0H | Serial operation mode register (CSIM) | | | W | - | _ | 0 | | | | | | CSIE | COI | WUP | | R/W | 0 | 0 | J | mem. bit | | | FE2H | CMDD | RELD | CMDT | RELT | | | | | | Only bit manipulation | | | SBI con | trol registe | er (SBIC) | | R/W | 0 | - 1 | - | mem. bit | can be performed on | | | BSYE | ACKD | ACKE | ACKT | 1 | | | | | any bit. | | FE4H | Serial I/0 | O shift reg | ister (SIO | ) | R/W | _ | - | 0 | | | | FE6H | Slave ac | dress reg | jister (SV | <b>A</b> ) | W | - | | 0 | | | | FE8H | PM33 | PM32 | PM31 | PM30 | | | | | | | | | Port mode register group A (PMGA) | | | (PMGA) | w | - | - | 0 | | | | | PM63 | PM62 | PM61 | PM60 | | | | | | | | FECH | - PM2 | | | | | | | | | | | | Port mode register group B (PMGB) | | | w | - | - | 0 | | | | | | PM7 | 0 | PM5 | PM4 | | | | | | | | FEEH | | | | PM8 | | | | | | | | | Port mo | de registe | r group C | (PMGC) | w | - | - | 0 | | | | | | | | | | | | | | | Remarks: 1. IExxx is an interrupt enable flag. 2. IRQxxx is an interrupt request flag. 3. IME is an interrupt master flag. (to be continued) Figure 3.2-1 µPD7500X I/O Map (con`t) | Address | Hardware name (abbreviation) | | | | per of bit<br>e manip | | Bit manipulation | Remarks | | | |---------|------------------------------|----------|-----|--------|-----------------------|-----|------------------|-----------|------------|---------| | Address | | | | | I T/ VV | One | Four | Eight | addressing | nemarks | | | b3 | b2 | b1 | b0 | | bit | bit | bit | | | | FF0H | Port 0 | | (PC | RT 0) | R | 0 | 0 | | | | | FF1H | Port 1 | (PORT 1) | | | R | 0 | 0 | | | | | FF2H | Port 2 | (PORT 2) | | R/W | 0 | 0 | | fmem, bit | | | | FF3H | Port 3 | (PORT 3) | | | R/W | 0 | 0 | | | | | FF4H | Port 4 | (PORT 4) | | | R/W | 0 | 0 | 0 | pmem. @L | | | FF5H | Port 5 | | (PC | PRT 5) | R/W | 0 | 0 | | Ten grant | | | FF6H | KR3 | KR2 | KR1 | KR0 | 544 | | | | | | | (Note) | Port 6 | (PORT 6) | | R/W | 0 | 0 . | | | | | | FF7H | KR7 | KR6 | KR5 | KR4 | R/W | 0 | 0 | 0 | | | | (Note) | Port 7 | (PORT 7) | | FI/W | | | | | | | | FF8H | Port8 | | (PC | PRT8) | R/W | 0 | 0 | _ | | | Note: KR0-KR7 can only be read. When 4bit parallel is input, specified at PORT6 or PORT7. Figure 3.2-1 µPD7500X I/O Map (con`t) ## **4 INTERNAL CPU FUNCTIONS** 4.1 Program Counter (PC) –12–Bit (μPD75004) 13–Bit (μPD75006, 75008) The program counter is binary counter which holds program memory address information. The µPD75004 is configured of 12-bit (See Fig. 4.1–1 (a)). The µPD75006 and 75008 are configured of 13-bit (See Fig. 4.4–1 (b)).0 (a) µPD75004 format | _ | | | | | | _ | | | | | | |------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | (b) µPD75006 and 75008 format | PC12 PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | |-----------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| Figure 4.1-1 Program Counter Format Each time one instruction is executed, normally the program counter is automatically incremented according to the number of the bytes in the instruction. When a branch instruction (BR or BRCB) is executed, the register pair contents or immediate data indicating the branch destination address is loaded into all or some of the PC bits. When a subroutine call instruction (CALL or CALLF) is executed or a vectored interrupt occurs, the current PC contents (return address already incremented to fetch the next instruction) are saved in stack memory (data memory indicated by the stack pointer), then the jump destination address is loaded. When a return instruction (RET, RETS, or RETI) is executed, the stack memory contents are loaded into the PC. When the RESET signal is generated, the program memory contents are loaded into the program counter for initialization, as follows: (Program can be started at any desired address.) µPD75004: PC11−PC8 low-order four bits at address 0000H PC7 -PC0 - eight bits at address 0001H μPD75006, μPD75008: PC12–PC8 ← low-order five bits at address 000H PC7 -PC0 eight bits at address 0001H 4.2 Program Memory (ROM) - 4096 Words x Eight bit (µPD75004) 6016 Words x Eight bit (μPD75006) 8064 Words x Eight bit (μPD75008) 0004 Words X Light bit (μι 270000) The program memory stores programs, interrupt vector table, GETI instruction look up table, and data such as table data. The program memory of the $\mu$ PD75004, $\mu$ PD75006, $\mu$ PD75008, is mask programmable ROM. Fig. 4.2-1 to 4.2-5 show the program memory map. The program memory is addressed by using the program counter. Table data can also be referenced by using the table reference instruction (MOVT). The address range for branching by a branch or subroutine call instruction is as shown in Fig. 4.2–1. When a relative branch instruction (BR \$addr) is used, a branch can be made to [PC contents – 15 to –1, +2 to + 16] address independently of block. The program memory addresses are shown below. The following addresses are assigned for special purpose: (All the area except address 0000H to 0001H Note 1 can be used as normal program memory area.). #### 0000H – 0001H Vector address table in which the program start address and MBE setup value are entered when the system is reset. (Reset start can be made at any desired address.) ### • 0002H - 000BH Vector address table in which the program start address and MBE setup value are entered for each vectored interrupt. (Interrupt service can be started at any desired address.) - 0020H 007FH Table area referenced by GETI (Note 2). - Note: 1. Their addresses are used in the µPD7500X. - The GETI instruction is used to convert any 2- or 3-byte instruction or any two 1-byte instructions into a 1-byte instruction. The number of program bytes can be reduced. Figure 4.2-1 Program Memory Map (μPD75004) Figure 4.2–2 Program Memory Map (μPD75006) Figure 4.2-3 Program Memory Map (μPD75008) ## 4.3 Data Memory (RAM) - 512 Words x Four Bits The data memory is a general purpose static RAM consisting of 512 words x four bits. Since a static RAM stores data during process, subroutine, or interrupt execution, it can also hold data when CPU operation is stopped in the standby mode; it is useful in that the memory contents can be held with battery power for hours. Fig. 4.3-1 shows a μPD7500X data memory map. The data memory adopts the bank configuration, consisting of banks 0 and 1 (each 256 words x four bits). Peripheral hardware is mapped in the memory bank 15 area. A memory bank is selected by setting the 4-bit memory bank selection register (MBS = 0, 1, or 15) when bank specification is enable by setting the memory bank enable flag (MBE) to 1 (MBE = 1). When bank specification is disabled (MBS = 0), memory bank 0 or 15 is automatically selected according to the current addressing mode. Each bank is addressed by using 8-bit immediate data, a register pair, etc. Although a data memory word consists of four bits, the data memory can be handled in 1-, 4-, or 8-bit units by using various addressing modes. See 3.1 for details of memory bank selection and addressing modes. Specific areas of the data memory are also used for general purpose registers (bank 0; 000H – 0007H) and stack memory (bank 0; 000H – 0FFH). Data memory does not exist in bank 15. Peripheral hardware and various registers are mapped. Do not access addresses or bits to which no registers are allocated. For the use of the specific areas of data memory, see the following: - · 4.4 for the general purpose register area - · 4.6 for the stack memory area - · CHAPTER 5 for the peripheral hardware Figure 4.3-1 Data Memory Map When reset is executed, the contents of the data memory are undefined. Therefore, normally, the data memory must be initialized at the beginning of the program execution (RAM clear). If this initialization is not performed, unexcepted malfunctions may result. Example: To clear the RAM mapped to addresses 04H to 1FFH: | | SEL | MB0 | | |--------|------|----------|---------------------------------| | | MOV | XA, #00H | | | | MOV | HL, #04H | ; Clears addresses 04H to FFH | | RAMC0: | MOV | @HL, A | ; (HL) < A | | | INCS | L | ; L = L + 1 | | | BR | RAMC0 | | | | INCS | Н | ; H = H + 1 | | | BR | RAMC0 | | | | SEL | MB1 | | | RAMC1: | MOV | @HL, A | ; Clears addresses 100H to 1FFH | | | INCS | L | | | | BR | RAMC1 | | | | INCS | H | | | | BR | RAMC1 | | | | • | | | # 4.4 General Purpose Registers - Eight x Four Bits The general purpose registers are eight 4-bit registers (B, C, D, E, H, L, X, and A) mapped in specific addresses of the data memory. Every general purpose register is handled in 4-bit units; register pairs BC, DE, HL, and XA are also used for 8-bit manipulation. In addition to DE and HL, registers D and L are also paired (DL), and the three register pairs can be used for data pointers. The general purpose register area can be addressed and accessed as normal RAM regardless of whether or not it is used for registers. | | Х | | А | | |------|---|-----|---|-----| | | | 01H | | 00H | | | Н | | L | | | - | | 03H | | 02H | | | D | | E | | | | | 05H | | 04H | | 1: . | В | 1.5 | С | | | l | | 07H | | 06H | Figure 4.4-1 General Purpose Register Configuration (When 4-bit processing is performed) | XA | 00H | |----|-----| | HL | 02H | | DE | 04H | | ВС | 06H | Figure 4.4–2 General Purpose Register Configuration (When 8-bit processing is performed) Figure 4.4-3 Register Pair Configuration #### 4.5 Accumulator The $\mu$ PD7500X uses the A register and XA register pair for accumulators. The A register is used as the main register during execution of 4-bit data processing instructions; the XA register pair is used as the main register pair during execution of 8-bit data processing instructions. The carry flag (CY) is used for a bit accumulator during execution of bit manipulation instructions. Figure 4.5-1 Accumulator #### 4.6 Stack Pointer (SP) - Eight Bits The $\mu PD7500X$ uses general purpose RAM for stack memory (LIFO). The stack pointer (SP) is an 8-bit register which holds top address information of the stack area. The stack area addresses are 000H–0FFH of memory bank 0 regardless of how MBE and MBS are set. SP is decremented before data is saved in the stack memory (write operation); it is incremented after data is restored from the stack memory (read operation). Figs. 4.6–2 to 4.6–4 shows data saved in and restored from the stack memory when stack operations are performed. An initial value is set in SP by using an 8-bit memory operation instruction to determine the stack area to be used. The SP contents can also be read. SP0 is always set to 0. It is recommended that the initial value of SP should be set to 00H so that the stack area be used is starting at the most significant address of data memory bank 0 (0FFH). When the RESET signal is generated, the SP contents become undefined. Be sure to initialize SP to the desired value at the start of the program. Example: To initialize SP. Figure 4.6-1 Stack Pointer Configuration ## (a) Data Saved in Stack Memory ## (b) Data Restored from Stack Memory Figure 4.6-2 Data Saved / Restore of Operation (µPD75004) ## (a) Data Saved in Stack Memory # (b) Data Restored from Stack Memory Figure 4.6-3 Data Saved / Restored in Stack Operation (μPD75006, 75008) ## 4.7 Program Status Word (PSW) - Eight Bits The program status word (PSW) consists of flags closely related to processor operation. PSW is mapped in data memory addresses FB0H and FB1H. Two bits of address FB0H can be operated by using a memory operation instruction. Figure 4.7-1 Program Status Word Configuration Table 4.7-1 PSW Flags Saved and Restored when Stack Operation is Performed | Save | During CALL, CALLF instruction execution | MBE is saved | | | | | |---------|------------------------------------------|---------------------------|--|--|--|--| | Save | During hardware interrupt | All PSW bits are saved | | | | | | Restore | During RET, RETS instruction execution | MBE is restored | | | | | | nestore | During RETI instruction execution | All PSW bits are restored | | | | | ## (1) Carry flag (CY) The carry is a 1-bit flag that shows the occurence of overflow or underflow during execution of an instruction involving carry (ADDC or SUBC). The carry flag also serves as a bit accumulator. Boolean algebra operation is performed between the bit accumulator and data memory specified by a bit address. The result can be stored in the bit accumulator. The carry flag is operated by using dedicated instructions independently of other PSW bits. When the RESET signal is generated, the carry flag becomes undefined. Table 4.7-2 Carry Flag Operation Instructions | | Instructions (mnemonic) | Carry flag processing | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------| | Instructions dedicated to carry flag operation | SET1 CY<br>CLR1 CY<br>NOT1 CY<br>SKT CY | CY is set to 1<br>CY is cleared<br>CY is inverted<br>Skip if CY is set to 1 | | Bit Boolean instructions | AND1 CY, mem*.bit<br>OR1 CY, mem*.bit<br>XOR1 CY, mem*.bit | The specified bit and CY are ANDed, ORed, or XORed together | | la de constante de la constant | During interrupt execution | CY is saved in stack<br>memory in parallel with<br>other PSW bits (eight bits) | | Interrupt service | RETI | CY is restored from stack<br>memory in parallel with<br>other PSW bits | Remarks: mem\*.bit indicates any of the following three bit 3 manipulation addressing modes - · fmem.bit - pmem.@L - @H + mem.bit Example: To AND bit 3 of address 3H and P33 together and set the result in CY. CLR1 MBE ; Or SEL MB0 SKT 3FH. 3; Skip if bit 3 of address 3FH is set to 1. CLR1 CY ; CY ← 0 AND1 CY PORT3.3 : CY ← CY ^ P33 (2) Skip flags (SK2, SK1, and SK0) The skip flags store the skip state and are automatically set or reset when the CPU executes instructions. The user cannot directly use the flags as operands. (3) Interrupt status flag (IST0) The interrupt status flag stores the current status of processing being performed. (For details, see Table 6.3-2.) Table 4.7-3 Interrupt Status Flag Indication Contents | IST0 | Status of processing being performed | Processing contents and interrupt control | |------|--------------------------------------|---------------------------------------------------------------------------| | 0 | Status 0 | During normal program processing.<br>Every interrupt can be acknowledged. | | 1 | Status 1 | During interrupt processing.<br>No interrupt must be acknowledged. | If an interrupt is acknowledged, the IST0 contents are saved in stack memory as a PSW bit, then automatically IST0 is set to 1. When an RETI instruction is executed, IST0 is set to 0. The interrupt status flag can be operated by using a memory operation instruction. The current status of processing can also be changed under program control. Caution: Before operating the flag, be sure to execute a DI instruction to disable interrupts. After operating the flag, execute an EI instruction to enable interrupts. ## (4) Memory bank enable flag (MBE) The memory bank enable flag is a 1-bit flag used to specify the address information generation mode of the high-order four bits of a 12-bit data memory address. MBS can be set or reset at any time by using a bit manipulation instruction regardless of memory bank setting. Example: SET1 MBE ; MBE ← 1 CLR1 MBE : MBE ← 0 When MBE is set to 1, the data memory address space is exceeded and all the data memory space can be addressed. When MBE is reset to 0, the data memory address space is fixed regardless of how MBS is set. (see Fig. 3.1-2.) When the RESET signal is generated, the contents of program memory address 0 bit 7 are set and MBE is initialized automatically. When vectored interrupt service is made, bit 7 of the corresponding vector address table is set and the MBE state during interrupt service is set automatically. During interrupt service, normally MBE is set to 0 and the general purpose RAM of memory bank 0 is used. ### 4.8 Bank Selection Register (BS) The memory bank selection register (MBS) for selecting a memory bank is mapped in the bank selection register (BS). The low-order four bits of BS are fixed to 0 MBS is set by using the SEL MBn instructions. BS can be saved in and restored from the stack area in 8-bit units by using PUSH BS instructions. | MBS — | | | | | | | | Symbol | |-------|------|------|------|---|---|-----|---|--------| | 7 | 6 | 5 | 4 | 3 | 2 | . 1 | 0 | | | MBS3 | MBS2 | MBS1 | MBS0 | 0 | 0 | 0 | 0 | BS | Figure 4.8-1 Bank Selection Register Configuration ## (1) Memory bank selection register (MBS) The memory bank selection register (MBS), consisting of four bits, stores high-order 4-bit address information of a 12-bit data memory address. The memory bank to be accessed is specified according to the register contents. However, the µPD7500X allows the user to select bank 0, bank 1, or bank 15 only. MBS is set by using the SEL MBn instruction (where n is 0, 1, or 15). The address range applied according to how MBE and MBS are set is as shown in Fig. 3.1–2. When the RESET signal is generated, MBS is initialized to 0. # **5 PERIPHERAL HARDWARE FUNCTIONS** # 5.1 Digital Input / Output Ports The µPD7500X adopts memory mapped I/O. All input / output ports are mapped in the data memory space. | Address | 3 | 2 | 1 | 0 | | |---------|-----|-----|-----|-----|--------| | FF0H | P03 | P02 | P01 | P00 | PORT 0 | | FF1H | P13 | P12 | P11 | P10 | PORT 1 | | FF2H | P23 | P22 | P21 | P20 | PORT 2 | | FF3H | P33 | P32 | P31 | P30 | PORT 3 | | FF4H | P43 | P42 | P41 | P40 | PORT 4 | | FF5H | P53 | P52 | P51 | P50 | PORT 5 | | FF6H | P63 | P62 | P61 | P60 | PORT 6 | | FF7H | P73 | P72 | P71 | P70 | PORT 7 | | FF8H | | _ | P81 | P80 | PORT 8 | Figure 5.1-1 Data Memory Addresses of Digital Ports Table 5.1–2 lists the input / output port operation instructions. In addition to 4-bit input / output, 8-bit input / output and bit manipulation can be performed for PORT 4 to PORT 7 and very diverse control can be performed. Example: To test the P13 state and output value to ports 4 and 5 depending on the result. SKT PORT1.3 ; Skip if port 1 bit 3 is set to 1 MOV XA, #18H ; XA ← 18H String effect MOV XA, #14H ; XA ← 14H String effect SEL MB15 ; Or CLR1 MBE OUT PORT4, XA ; Ports 5,4 ☐ XA Example: SET1 PORT 4. @L ; The port 4-7 bit specified by using the L register is set to 1. 5.1.1 Types, features, and configurations of digital input / output ports Table 5.1-1 lists the digital input / output ports. Figs. 5.1-1 to 5.1-6 shows the port configurations. Table 5.1-1 Types and Features of Digital Ports | Port (abbreviation) | Function | Operation and features | Remarks | | |---------------------|-----------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------|--| | PORT 0 | 4-bit input | Can always be read or tested regardless | Pins also used for INT4, SCK<br>SO/SB0, SI/SB1, Pins also | | | PORT 1 | 4-bit input | of the operation mode. | used for INT0-2 and Ti0. | | | PORT 3(Note 1) | | Can be placed in input or output mode in 1-bit units. | Pins also used for<br>MD0–MD3, (Note 2) | | | PORT 6 | 4-bit input / output | iii i-bit driits. | Pins also used for KR0-KR3. | | | PORT 2 | 4-bit iliput / output | Can be placed in input or ouput mode in 4-bit units. Ports 6 and 7 can be | Port 2 pins are also used for PTO0, PCL, and BUZ. | | | PORT 7 | | paired for data input / output in 8-bit units. | Pins also used for KR4-KR7. | | | PORT 4(Note 1) | 4-bit input / output<br>(N-channel open | Can be placed in input or output mode in 4-bit units. Ports 4 and 5 can be paired | Internal pull-up resistor can be specified in 1-bit units by using | | | PORT 5(Note 1) | drain 10 Volts) | for data input / output in 8-bit units. | mask option. | | Note 1: An LED can be driven directly. Note 2: PORT 3 is also used for MD0-MD3 pin only in μPD75P008. The P10 pin is also used for an external vectored interrupt input pin (input with a noise removal circuit). (For details, see 6.3.) When the RESET signal is generated, port 2-port 8 output latches are cleared, the output buffers are turned off, and input mode is entered. Figure 5.1-2 Configuration of Ports 0 or 1 Figure 5.1-3 Configuration of port 3n or 6n (n = 0-3) Figure 5.1-4 Configuration of Port 2 or 7 Figure 5.1-5 Configuration of Port 4 or 5 Fig. 5.1-6 Port 8 Organization ### 5.1.2 Input / output mode setting The input or output mode of each input/output ports is set by using the port mode register as shown in Fig. 5.1–7. Each bit of ports 3 and 6 can be placed in input or output mode individually by using port mode register group A (PMGA). Each of ports 2, 4, 5, and 7 (four bits each) is placed in input or output mode individually by using port mode register group B (PMGB). Each port serves as an input port when the corresponding port mode register bit is set to = 0 and serves as an output port when set to 1. Since the output latch contents are applied to the output pins at the same time the output mode is selected by setting the port mode register, the output latch contents must previously be rewitten to the required value before the output mode is set. Port mode register groups A and B are set by using 8-bit memory operation instructions When the RESET signal is generated, all bits of the port mode registers are cleared; thus the output buffers are turned off, and all ports are placed in input mode. Example: To use P30, P31, P62, and P63 for input pins and P32, P33, P60, and P61 for output pins. | CLR1 | MBE | ; | Or SEL MB15 | |------|----------|---|-------------| | MOV | XA, #3CH | | | | MOV | PMGA, XA | | | ### Port mode register group A | 3 PM6 | | | | | | | Symbol | | | |-----------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------|--------------------------------|--|--| | | 2 PM61 | PM60 | PM33 | PM32 | PM31 | PM30 | PMGA | | | | Bn P3n, F | P3n, P6n pin input / output specification (n = 0-3) | | | | | | | | | | Input | mode (output b | ouffer off) | | | | | | | | | Outpu | t mode (output | buffer on) | | | | | | | | | | Р | ort mode re | gister group | В | | | | | | | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | | | | 7 – | PM5 | PM4 | _ | PM2 | _ | | PMGB | | | | n Port n | Port n input / output specification (n = 2, 4, 5, or 7) | | | | | | | | | | Input | mode (output b | ouffer off) | | | | - | | | | | Outpu | Output mode (output buffer on) | | | | | | | | | | | Р | ort mode re | gister group | С | | | | | | | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | | | | | | _ | _ | - | _ | PM8 | PMGC | | | | n Port 8 | input specifica | ition | | | | | | | | | Input | nput mode (output buffer off) | | | | | | | | | | Outpu | t mode (output | buffer on) | | | | | | | | | | 6 Output Input i | Input mode (output be output mode (output mode (output mode (output mode for mode)) From Port n input / output input mode (output mode) Output mode (output mode) From Port 8 input specification input mode (output be mode) | Input mode (output buffer off) Output mode (output buffer on) Port mode re 6 5 4 7 - PM5 PM4 In Port n input / output specification Input mode (output buffer off) Output mode (output buffer on) Port mode re 6 5 4 | Input mode (output buffer off) Output mode (output buffer on) Port mode register group 6 5 4 3 7 - PM5 PM4 - In Port n input / output specification (n = 2, 4, 5) Input mode (output buffer off) Output mode (output buffer on) Port mode register group 6 5 4 3 n Port 8 input specification Input mode (output buffer off) | Input mode (output buffer off) | Input mode (output buffer off) | Input mode (output buffer off) | | | <sup>-:</sup> May be 0 or 1. Figure 5.1-7 Port Mode Register Formats ### 5.1.3 Digital input / output port operation instructions Since all input / output ports incorporated in the $\mu$ PD7500X are mapped in the data memory space, all the data memory operation instructions are applicable. Table 5.1–2 lists the data memory operation instructions particularly useful for input / output pin operation and their application ranges. ### (1) Bit operation instructions The specific address bit direct addressing (fmem. bit) and specific address bit register indirect addressing (pmem. @L) modes are applicable to digital input / output ports PORT 0-PORT 7. The port bits can be operated at any time as desired regardless of how MBE and MBS are set. Example: To OR P50 and P41 together and output the result to P61. ``` CY 1 SET1 CY AND1 CY, PORT5.0 CY← CY∧ P50 ; OR1 CY, PORT4.1 CY ← CYVP41 SKT CY BR CLRP PORT6.1 P61 <del>←</del> 1 SET1 ``` ## (2) 4-bit operation instructions In addition to the IN and OUT instructions, all 4-bit memory operation instructions such as MOV, XCH, ADDS, and INCS can be used. However, memory bank 15 must have been selected before executing an instruction. Example 1: To output the accumulator contents to port 3. ``` SEL MB15 ; Or CLR1 MBE OUT PORT3, A ``` Example 2: To add the accumulator value to the data output to port 5 and output the result. ``` SET1 MBE SEL MB15 MOV HL, #PORT5 ADDS A, @HL ; A → A+PORT5 NOP MOV @HL, A : PORT5 → A ``` Example 3: To test whether or not data in port 4 is greater than the accumulator value. ``` SET1 MBE SEL MB15 MOV HL, #PORT4 SUBS A, @HL ; A<PORT4 BR NO ; NO : YES ``` ### (3) 8-bit operation instructions In addition to the IN and OUT instructions, the MOV, XCH and SKE instructions can be used for ports 4 and 5 where 8-bit operation (manipulation) can be performed. As with the 4-bit operation instructions, memory bank 15 must have been selected before executing the instruction. Example: To output data in the BC register pair to the output ports specified by the 8-bit data input from ports 4 and 5. | SEI1 | MBE | | | |------|------------|---|--------------------| | SEL | MB15 | | | | IN | XA, PORT 4 | ; | XA ports 5 and 4 | | MOV | HL, XA | ; | HL <del>▼</del> XA | | MOV | XA, BC | ; | XA <del>←</del> BC | | MOV | @HL, XA | ; | Port (L) | Table 5.1-2 Input / Output Port Pin Operation Instruction List | PORT Instruction | PORT 0 | PORT 1 | PORT 2 | PORT 3 | PORT 4 | PORT 5 | PORT 6 | PORT 7 | PORT 8 | |-----------------------------|--------|--------|--------|-----------|--------|--------|--------|--------------|--------| | IN A, PORTn (Note 1) | 0 | | | | | | | | | | IN XA, PORTn (Note 1) | | | | - *** | ( | ) | | ) | - | | OUT PORTn. A (Note 1) | · | | | | | 0 | | : | | | OUT PORTn. XA (Note 1) | - | _ | | _ | | ) | ( | ) | _ | | SET1 PORTn. bit | | - | | | | 0 | | | | | SET1 PORTn. @L (Note 2) | _ | | | - | | 0 | | | | | CLR1 PORTn. bit | | _ | | ara, etc. | 11 876 | 0 | | ere Sak Turr | 19 20 | | CLR1 PORTn. @L (Note 2) | _ | - | | | | 0 | | | | | SKT PORTn. bit | | | | | 0 | | | | | | SKT PORTn. @L (Note 2) | | | | | 0 | | | | | | SKF PORTn. bit | | | | | 0 | | | | | | SKF PORTn. @L (Note 2) | | | | | 0 | | | | | | AND1 CY, PORTn. bit | | | | | 0 | | | | | | AND1 CY, PORTn. @L (Note 2) | | | | | 0 | | | | | | OR1 CY, PORTn. bit | | | | | 0 | | | | | | OR1 CY, PORTn. @L (Note 2) | | | | | 0 | | | | | | XOR1 CY, PORTn. bit | - | | | | 0 | | | | | | XOR1 CY, PORTn. @L (Note 2) | | | | | 0 | | | | | Note 1: MBE = 0 or (MBE = 1 and MBS = 15) must have been set before executing the instruction. # 5.1.4 Digital input / output port operation When data memory operation instructions are executed for the digital input / output ports, port (pin) operation varries according to which mode (input or output) is set. (See table 5.1–3.) This is because as understood from the input / output port structure, data read into the internal bus is data for each pin in the input mode and output latch data in the output mode. ## (1) Operation when input mode is set Pin data is operated when executing a test instruction such as SKT or an instruction to read 4- or 8-bit port data into the internal bus (IN, OUT, operation, or comparison instruction). When an instruction to transfer the accumulator contents (four or eight bits) to a port or ports is executed (OUT or MOV instruction), the accumulator data is latched in the output latches. The output buffers remain off. When an XCH instruction is executed, pin data is input to the accumulator and the accumulator data is latched in the output latches. The output buffers remain off. When an INCS instruction is executed, data resulting from adding 1 to 4-bit pin data is latched in the output latches. The output buffer remain off. When an instruction to rewrite data memory bitwise is executed, such as SET1, CLR1, or SKTCLR, (the specified bit output latch can be rewritten as specified by instruction), but the contents of the output latch for other bits become undefined. <sup>2:</sup> The low-order two bits of address and the bit address are specified indirectly by using the L register. (2) Operation when output mode is set When a test instruction or an instruction to read 4- or 8-bit port data into the internal bus is executed, the output latch contents are operated. When an instruction to transfer the accumulator contents (four or eight bits) is executed, output latch data is rewritten and at the same time as output from the pins. When an XCH instruction is executed, the output latch contents are transferred to the accumulator, and the accumulator contents are held in the output latches and is output from the pins. When an INCS instruction is executed, data resulting from incrementing the output latch contents by one is held in the output latches and output from the pins. When a bit output instruction is executed, the specified output latch bit is rewitten and output from the pin. Table 5.1-3 Operation When Input / Output Ports are Used | Executed | Port (pin) | operation | |---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | instruction | Input mode | Output mode | | SKT ① | Pin data is tested. | Output latch is data tested. | | AND1 CY, ① OR1 CY, ① XOR1 CY, ① | Operation is performed between pin data and CY. | Operation is performed between output latch data and CY. | | IN A, PORTn<br>IN XA, PORTn<br>MOV A, @HL<br>MOV XA, @HL | Pin data is transferred to accumulator. | Output latch data is transferred to accumulator | | ADDS A, @HL ADDC A, @HL SUBS A, @HL SUBC A, @HL AND A, @HL OR A, @HL XOR A, @HL | Operation is performed between pin data and accumulator. | Operation is performed between output latch data and accumulator. | | SKE A, @HL | Pin data and accumulator contents are compared. | Output latch data and accumulator contents are compared. | | OUT PORTn, A<br>OUT PORTn, XA<br>MOV @HL, A<br>MOV @HL, XA | Accumulator data is transferred to output latches. (Output buffers remain off.) | Accumulator data is transferred to output latches and output from the pins. | | XCH A, PORTN<br>XCH XA, PORTN<br>XCH A, @HL<br>XCH XA, @HL | Pin data is transferred to accumulator and accumulator data is transferred to output latches. (Output buffers remain off.) | Data is exchanged between output latches and the accumulator. | | INCS PORTn<br>INCS @HL | Data resulting from incrementing pin data by one is latched in output latches. | The output latch contents are incremented by one. | | SET1 ① CLR1 ① SKTCLR ① | The specified bit output latches are rewritten as specified by the instruction, but the output latch contents for other bits are undefined. | The output pin state is changed according to the instruction. | : Denotes two addressing modes PORTn. bit and PORTn. @L. ## 5.1.5 Internal pull-up resistors Pull-up resistors can be incorporated in the $\mu$ PD7500X port pins except for P00. Internal pull-up resistors are specified by using software or mask option. | | Specification | |---|---------------------------------------| | 0 | Pull-up resistor is not incorporated. | | 1 | Pull-up resistor is incorporated. | Figure 5.1-8 Pull-Up Register Specification Register Format Table 5.1-4 | Port (Pin name) | Specification method to provide pull-up resistor | POGA bit | POGB bit | |---------------------------|--------------------------------------------------|----------|----------| | Port 0 (P01-P03) (Note 1) | By means of software in 3-bit units. | Bit 0 | | | Port 1 (P10-P13) | | Bit 1 | _ | | Port 2 (P20-P23) | | Bit 2 | _ | | Port 3 (P30-P33) | By means of software in 4-bit units. | Bit 3 | _ | | Port 6 (P60-P63) | | Bit 6 | _ | | Port 7 (P70-P73) | | Bit 7 | _ | | Port 4 (P40-P43) | Dy mack antion in 1 hit units | | | | Port 5 (P50-P53) | By mask option in 1-bit units. | _ | _ | | Port 8 (P80-P81) | By means of software in 2 bit units. | _ | Bit 0 | Note: A pull-up resistor cannot be provided for the P00 Pin. # 5.1.6 Digital input / output port input / output timing Fig. 5.1-9 shows timing of data to output latch and timing of pin data or output latch data input to the internal bus. Fig. 5.1-10 shows the ON timing at specified the internal pull-up resistor by software. Figure 5.1-10 ON Timing of Pull-up Resistor by using Software #### 5.2 Clock Generator The clock generator supplies clocks to CPU and peripheral hardware for controlling the CPU operating mode. 5.2.1 Clock generator configuration Fig. 5.2-1 shows a clock generator block diagram. $2.f_{\text{XT}}^{\Lambda}$ : Subsystem clock frequency 3. PCC: Processor clock control register 4. SCC : System clock control register 5. \* denotes instruction execution. Figure 5.2-1 Clock Generator Block Diagram #### 5.2.2 Clock generator function and operation The clock generator produces the following clocks and controls CPU operating modes such as standby: - Main system clock fx - Subsystem clock fy - CPU clock ø - Clock to peripheral hardware The clock generator operates according to how the processor clock control register (PCC) and system clock control register (SCC) are set, as described below: - (a) When the RESET signal is generated, the minimum speed mode of the main system clock (15.3 µ/4.19 MHz) is selected. (PCC = 0 and SCC = 0) - (b) When the main system clock is selected, one of three CPU clock frequencies can be selected (0.95 μs, 1.91 μs, and 15.3 μs/ 4.19 MHz) by setting PCC. - (c) When the main system clock is selected, the standby mode (STOP or HALT) can be used. - (d) Subsystem clock is selected by setting SCC.0, and operation can be performed in a very low-speed and low current consumption (122 μs/32.768 kHz). In this case, the PCC setup value does not affect the CPU clock. - (e) When the subsystem clock is selected, main system clock oscillation can be stopped by setting SCC.3. The HALT mode can also be used, but the STOP mode cannot be used. (Subsystem clock oscillation cannot be stopped.) - (f) The main system clock is divided to generate a clock supplied to peripheral hardware. The subsystem clock can be supplied directly only to the watch timer. Thus, the watch function and the LCD controlller and buzzer output function which operate using the watch timer clock can also continue operation in the standby mode. - (g) When subsystem clock is selected, the watch timer and LCD controller can continue normal operation. When the main system clock is stopped, other hardware devices than the watch timer cannot be used because they operate according to the main system clock. - (1) Processor clock control register (PCC) PCC consists of four bits; the low-order two bits are used to select CPU clock $\phi$ , and the high-order two bits are used to control CPU operation mode. (See Fig. 5.2-2.) When bit 3 or 2 is set to (1), the standby mode is set. When the standby mode is released by the standby mode release signal, automatically bits 3 and 2 are cleared and the normal operating mode is entered. (For details, see Paragraph 7). The low-order two bits of PCC are set by using a 4-bit memory operation instruction (the high-order two bits are set 0). Bits 3 and 2 are set to (1) by using STOP and HALT instructions respectively. The STOP and HALT instructions can always be executed independently of the MBE contents. CPU clock can be selected only during main system clock operation. When the $\mu$ PD7500X is operated on the subsystem clock, the low-order two bits of PCC becomes invalid, and the CPU clock is fixed to $f_{\chi\gamma}$ 4. The stop instruction is also enabled only during main system operation. Example 1: To set a machine cycle to 0.95 µs (4.19) MHz). SEL MB15 MOV A, #0011B MOV PCC A Example 2: To set STOP mode. (Be sure to enter a NOP instruction following the STOP or HALT instruction.) STOP NOP When the RESET signal is generated, PCC is cleared. Figure 5.2-2 Processor Clock Control Register Format # (2) System clock control register (SCC) SCC consists of four bits; the least significant bit is used to select CPU clock, and the most significant bit is used to control (stop) main system clock oscillation. (See Fig. 5.2–3.) SCC 0 and SCC 3 exist at the same data memory address; the bits cannot be changed at the same time. Thus, SCC 0 and SCC 3 are set by using a bit operation instruction. SCC 0 and SCC 3 can always be operated independetly of the MBE contents. Main system clock oscillation can be stopped by setting SCC 3 only during subsystem clock operation. Main system clock oscillation is stopped by using the STOP instruction during main system clock operation. When the RESET signal is generated, SCC is cleared. Figure 5.2-3 System Clock Control Register Format - Caution 1: Changing the system clock requires a maximum of 1/f<sub>XT</sub> time. To stop main system clock after changing the subsystem clock, set SCC 3 after the machine cycle or cycles listed in Table 5.2–1. - 2: Even if oscillation is stopped by setting SCC 3 during main system clock operation, normal STOP mode is not entered. - 3: When SCC.3 is set to 1, X1 input is connected internally to V<sub>ss</sub>, to avoid leakage current due to crystall oscillator. When the external clock is used in main system clock, do not set SCC.3 to 1. - 4: When the system clock is switched to the subsystem clock it is necessary to disable any interrupt during the time given in table 5.2-1. ## (3) System clock oscillators The main system clock oscillator uses a crystal oscillator (4.194304 MHz standard) or cermanic oscillator connected to the X1 and X2 pins. An external clock can also be input. Figure 5.2-4 External Circuit to Main System Clock Oscillator Caution: When an external clock is input, the STOP mode cannot be set because the X1 pin is connected to VSS in the STOP mode. The subsystem clock oscillator uses a crystal oscillator (32.768 kHz standard) connected to the XT1 and XT2 pins. An external clock can also be input. The XT1 pin state can be tested by using watch mode register (WM) bit 3. Figure 5.2-5 External Circuit to Subsystem Clock Oscillator (4) Frequency divider The frequency divider divides the main system clock oscillator output (f<sub>v</sub>) and generates various clocks. 5.2.3 System clock and CPU clock setting (1) Time required to change system and CPU clocks The system and CPU clocks can be changed by using the low-order two bits of PCC and the least significant bit of SCC. However, this clock change is not immediatly made after the register are rewritten, and the clock before the clock change is made is used for operation during given machine cycles. Thus, to stop main system clock oscillation, a STOP instruction must be executed or SCC 3 must be set after the change time elapses. Table 5.2-1 Maximum Time Required to Change System and CPU Clocks | Setup value<br>before change | | Setup value after change | | | | | | | | | | | | | | |------------------------------|-----|--------------------------|--------------------------------------------------------------------|-----------|---------------------------------------------|---------------------------|-------------------|-----------------|----------------------------------------------------------------------|------|--------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------|------|--| | scc | PCC | PCC | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | | | 0 | 1 | 0 | 0 | 0 | 0 | . 0 | 1 | 0 | 0 | 1 | 1 | 1 | Х | Х | | | | 0 | 0 | | | 1 machine cycle | | | 1 machine cycle | | | f <sub>X</sub> machine 64f <sub>XT</sub> cycle (2 machine cycles) | | | | | | 0 | 1 | 0 | 8 ma | achine cy | /cles | | | | 8 machine cycles | | | f <sub>X</sub> machine 8f <sub>XT</sub> cycles (16 machine cycles) | | | | | | 1 | 1 | 16 m | achine c | ycles | 16 m | 16 machine cycles | | | | | | f <sub>X</sub> machine 4f <sub>XT</sub> cycles (32 machine cycles) | | | | 1 | х | х | f <sub>X</sub> machine 64f <sub>XT</sub> cycles (2 machine cycles) | | f <sub>X</sub><br>8f <sub>XT</sub><br>(16 m | mach<br>cycle<br>achine c | s | | f <sub>X</sub> machine 4f <sub>XT</sub> cycles (32 machine cycles) | | | | | | | The values enclosed in parentheses are applied when $f_X = 4.19$ MHz and $f_{XT} = 32.768$ kHz. Remarks: The CPU clock $\Phi$ is supplied to the $\mu$ PD7500X internal CPU. The reciprocal of the clock becomes the minimum instruction time. (The present manual defines it to be one machine cycle.) (2) System and CPU clock change sequence System and CPU clock change is explained using Fig. 5.2–6. - 1) When the RESET signal is generated, the CPU starts operating at the minimum speed of the main system clock (15.3 µs / 4.19 MHz) after the wait time (31.3 ms / 4.19 MHz) to allow time for stabilizing the oscillator. - After enough time has elapsed for the V<sub>DD</sub> pin voltage to rise to an adequate level PCC is rewritten and the μPD7500X operates at the maximum speed. - 3) Turning off the commercial power supply is detected by using interrupt input (INT4 is useful); SCC. 0 is set, and the µPD7500X operates using the subsystem clock. (At the time, a check must have been made to ensure that subsystem clock oscillation has started. After the time required to change to the subsystem clock (32 machine cycles) has elapsed, SCC 3 is set and main system clock oscillation is stopped. - 4) Restoration of the commercial power supply is detected by using an interrupt. SCC. 3 is cleared and main system clock oscillation is started. After the time required to stabilize oscillation has elapsed, SCC. 0 is cleared and the µPD7500X operates at the maximum speed. #### 5.2.4 Clock output circuit (1) Clock output circuit configuration Fig. 5.2-7 shows a clock output circuit block diagram. (2) Clock output circuit function The clock output circuit, which outputs clock pulses from the P22/PCL pin, is used to supply clock pulses to remote control output or peripheral LSIs. Clock pulses are output in the following sequence: - (a) Clock output frequency is selected. Clock output is disabled. - (b) 0 is written into P22 output latch. - (c) Port 2 input/output mode is placed in output mode. - (d) Clock output is enabled. Figure 5.2-7 Clock Output Circuit Block Diagram Remarks: The circuit is designed so as not to output a spurious short-width pulse when changing between clock output enable and disable. (3) Clock output mode register (CLOM) CLOM is a 4-bit register to control clock output. CLOM is set by using a 4-bit memory operation instruction. It cannot be read. Example: To output clock $\Phi$ from PCL/P22 pin. SEL MB15 ; Or CLR1 MBE MOV A. #1000B MOV CLOM, A When the RESET signal is generated, CLOM is cleared and clock output is disabled. Caution: Be sure to write 0 into CLOM bit 2. Figure 5.2-8 Clock Output Mode Register Format ### (4) Application example to remote control output The µPD7500X clock output function is applicable to remote control output. Remote control output carrier frequency is selected by using the clock frequency selection bit of the clock output mode register. Pulse output is enabled or disabled under software control by using the clock output enable/disable bit. It is designed so that a spurious short-width pulse will not be produced when changing between clock output enable and disable. Figure 5.2-9 Remote Control Output Application Example ## 5.3 Basic Interval Timer The µPD7500X contains an 8-bit basic interval timer which has the following functions: - (a) Reference time generation (four types of time interval) - (b) Wait time selection and count when standby mode is released. - (c) Count read The basic interval timer can also be applied to a watchdog timer to detect program overrun. ## 5.3.1 Basic interval timer configuration Fig. 5.3-1 shows the configuration of the basic interval timer Remarks: \* denotes instruction executing. Figure 5.3-1 Basic Interval Timer Configuration # 5.3.2. Basic interval timer mode register (BTM) BTM is a 4-bit register for controlling operation of the basic interval timer. BTM is set by using a 4-bit memory operation instruction. Bit 3 can be set individually by using a bit operation instruction. Example 1: To set the interrupt generation interval to 1.95 ms (4.19 MHz). SEL MB15 ; or CLR1 MBE MOV A, # 1111B Example 2: To clear BT and IRQBT (watchdog timer application). SEL MB15 ; or CLR1 MBE SET1 BTM.3 ; BTM BIT 3 is set to 1. When bit 3 is set to 1, the basic interval timer contents are cleared. At the same time, the basic interval interrupt request flag (IRQBT) is also cleared. (The basic interval timer starts.) When the RESET signal is generated, the BTM contents are cleared and interrupt request signal generation is set for the longest interval. Fig. 5.3-2 Basic Interval Timer Mode Register Format #### 5.3.3. Basic interval timer operation The basic interval timer (BT) is incremented each time a pulse is received from the clock generator. When an overflow occurs, the interrupt request flag (IRQQBT) is set. BT count operation cannot be stopped. An interrupt generation time interval can be selected from among four types by setting BTM. (See Fig. 5.3—2.) The basic interval timer and interrupt request flag can be cleared by setting BTM bit 3 to 1 (the interval timer function starts). The basic interval timer (BT) count can be read by using an 8-bit operation instruction. Data cannot be written into BT. ### Caution: To prevent reading of unstable data during count update when reading the basic interval timer count, execute the read instruction twice and compare the results. If they are valid values, the later read value is used as the read result, if they differ from each other completely, reexecute from the beginning. #### Example: To read the BT count | LOOP: | SET1<br>SEL<br>MOV<br>MOV<br>MOV<br>MOV | MBE<br>MB15<br>HL, #BT<br>XA, @HL<br>BC, XA<br>XA, @ HL | ;; | BT address is set in HL.<br>First read<br>Second read | |-------|-----------------------------------------|---------------------------------------------------------|----|-------------------------------------------------------| | | SKE<br>BR | A, C<br>LOOP | , | Second read | | | MOV<br>SKE<br>BR | A, X<br>A, B<br>LOOP | | | The wait function is provided to stop CPU operation until the basic interval timer overflows in order to allow time for system clock oscillation to become stable when the STOP mode is released. Although the wait time after the RESET signal is generated is fixed, it can be selected by setting BTM when the STOP mode is released by an interrupt. The wait time is selected by setting BTM as shown in Fig. 5.3—2. BTM setting must be performed before the STOP mode is set. (For details, see CHAPTER 7.) # 5.3.4 Basic interval timer application examples Example 1: To enable basic interval timer interrupt and set interrupt generation interval at 1.95 ms (at 4.19 MHz). SEL MB 15 MOV A, #1111B MOV BTM, A ; BTM setting and timer function start EI ; Interrupt is enabled. EI IEBT : BT interrupt is enabled. Example 2: Watchdog timer application A program is divided into serval modules which terminate processing within the BT setup time. BT and IRQBT are cleared at the end of each module. If an interrupt is generated, overrun is assumed to have occured. SEL MB15 Initial- MOV A, #1101B ; 7.8 ms interval is set. izatiion MOV BTM, A ; BTM setting and timer function start EI EEI IEBT Example 3: To set the wait time, when the STOP mode is released, using an interrupt to 7.8 ms. SEL MB15 ; or CLR1 MBE MOV A, #1101B MOV BTM, A ; BTM ← 1101B STOP ; STOP mode is set NOP ### Example 4: To set the high-level width of a pulse input to INT4 interupt (both rising and falling edge detection). (The pulse width must not exceed the BT setup value. The BT setup value must be 7.8 ms or more.) < INT4 interrupt routine (MBE = 0) > ``` LOOP: MOV XA, BT First read Data is stored. MOV BC, XA XA, BT Second read MOV SKE A, C LOOP BR A, X MOV SKE A, B LOOP BR P00=1? SKT PORT0.0 BR AA NO Data is stored in data memory. MOV XA, BC MOV BUFF, XA CLR1 FLAG RETI AA: MOV HL, #BUFF MOV A, C SUBC A, @HL INCS L MOV C. A MOV A, X SUBC A, @HL MOV B, A MOV XA, BC MOV BUFF, XA Data is stored. Data existence flag is set. SET1 FLAG RETI ``` ### 5.4 Watch Timer The µPD7500X incorporates a watch timer (one channel) which has the following function: - (a) The test flag (IRQW) is set at 0.5 s time intervales. The standby mode can be released using IRQW. - (b) The main system and subsystem clocks can be assigned 0.5-s intervals. - (c) In the rapid feed mode, time intervals multiplied by 128 (3.91 ms) are enabled. The mode is useful for program debugging and testing. - (d) A fixed frequency (2.048 kHz) can be output to P23/BUZ. It can be used for sounding the buzzer and trimming the system clock oscillation frequency. - (e) Since the scaler can be cleared, the watch can be started at zero seconds. #### 5.4.1 Watch timer configuration Fig. 5.4-1 shows a watch timer block diagram. The values enclosed in parentheses are applied when $f_x = 4.194304$ MHz and $f_{xT} = 32.768$ kHz. Figure 5.4-1 Watch Timer Block Diagram ### 5.4.2 Watch mode register The watch dog timer (WM) consists of eight bits to control the watch timer. Fig. 5.4–2 shows the watch mode register format. The watch mode register (except bit 3) is set using an 8-bit operation instruction. Bit 3 is used to test the XT1 pin input level. The input level to the XT1 pin can be tested by making a bit test. When the RESET signal is generated, all bits except bit 3 are cleared. Example: To produce time using the main system clock (4.19 MHz). To enable buzzer output. CLR1 MOV MBE XA, #84H MOV WM. XA ; WM set Address | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------|-----|---|---|---|-----|-----|-----|-----|----| | F98H | WM7 | 0 | 0 | 0 | wмз | WM2 | WM1 | WM0 | WM | Count clock (f<sub>w</sub>) selection bit | WMO | 0 | System clock dividing output $\frac{f_X}{128}$ is selected. | |-----|---|-------------------------------------------------------------| | | 1 | Subsystem clock f <sub>XT</sub> is selected. | Symbol #### Operation mode selection bit | WM1 | 0 | Normal watch mode (IRQW is set by using $\frac{f_W}{2^{14}}$ , 0.5 s) | |-------|---|--------------------------------------------------------------------------| | VVIVI | 1 | Rapid feed watch mode (IRQW is set by using $\frac{f_W}{2^7}$ , 3.91 ms) | #### Watch operation enable/disable bit | WM2 | 0 | Watch operation is stopped (divider is cleared). | |--------|---|--------------------------------------------------| | VVIVIZ | 1 | Watch operation is enabled. | # Input level to XT1 pin (bit test only is enabled) | 14/14/2 | 0 | Input level to XT1 pin is low. | |---------|---|---------------------------------| | WM3 | 1 | Input level to XT1 pin is high. | ## BUZ output enable/disable bit | WM7 | 0 | BUZ output is disabled. | |-------|---|-------------------------| | VVIVI | 1 | BUZ output is enabled. | Figure 5.4-2 Watch Mode Register Format ## 5.5 Timer/event counter configuration The $\mu PD7500X$ incorporates a timer/event counter (one channel) as shown in Fig. 5.5–1. The timer/event counter functions are as follows: - (a) Programmable interval timer operation - (b) Any desired frequency square wave output to PTO0 pin - (c) Event counter operation - (d) TI0 pin input is divided by N output to PTO0 pin (scaler operation). - (e) Real shift clock supply to serial interface circuit - (f) Count read function Figure 5.5-1 Timer/Event Counter Block Diagram II-1-69 ### 5.5.2 Basic configuration and operation of timer/event counter The timer/event counter operation mode can be selected by using the timer/event counter mode register (TM0). The basic configuration and operation of the timer/event counter are explained below: - (1) Count pulse CP is selected by setting TM0 and input to the 8-bit count register T0. - (2) To is a binary 8-bit up counter incremented by one when CP is input. It is cleared when the RESET signal is generated, TM0 bit 3 is set (timer start), or coincidence signal is generated. T0 can be read at any time using an 8-bit memory operation instruction, but cannot be written - (3) The modulo register TMOD0 consists of eight bits to determine the T0 count. A value is set in TMOD0 using an 8-bit memory operation instruction, but TMOD0 cannot be read. When the RESET signal is generated, TMOD0 is initialized to FFH - (4) The comparator compares the T0 and TMOD0 contents. If they match, it generates a coincidence signal and sets the interrupt request flag (IRQT0) Fig. 5.5-2 shows the count operation timing. Figure 5.5-2 Count Operation Timing Chart # 5.5.3 Timer/event counter mode register (TM0) and timer/event counter output enable flag (TOE0) The mode register (TM0) consists of eight bits to control the timer/event counter. Fig. 5.5-3 shows the timer/event counter mode register format. The timer mode register is set by using an 8-bit memory operation instruction. Bit 3 is a timer start bit which can be set individually. Bit 3 is reset to 0 automatically when timer operation starts. Example 1: To start the timer in interval timer mode with CP = 4.09 kHz. SEL or CLR1 MBE MOV XA. #01001100B MOV TM0<sup>4</sup> 4CH TM0.XA Example 2: To restart the timer according to how the timer mode register is set. SEL MB15 ; or CLR1 MBE SET1 TM0.3 ; TM0.BIT3 ─ 1 When the RESET signal is generated, all the timer mode register bits are cleared. The timer/event counter output enable flag (TOE0) controls enable/disable of outputting the timer out F/F (TOUT F/F) state to the PT00 pin. (See Fig. 5.5–4.) It is operated by using bit operation instruction and is enable to be writing. The timer out F/F (TOUT F/F) is inverted by the coincidence signal received from the comparator. The timer out F/F is reset using an instruction to set timer mode register (TM0) bit 3. When the RESET signal is generated, TOE0 and TOUT F/F are cleared. Remarks: The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. Figure 5.5-3 Timer/Event Coumter Mode Register Format Figure 5.5-4 Timer/Event Counter Output Enable Flag Format ## 5.5.4 Timer/event counter operation mode The timer/event counter operates in the count operation stop or count operation mode depending on how the mode register is set. The following are always enabled independently of how the mode register is set - 1) TIO pin signal input and test. (P13 pin input test can be made.) - 2) Output of timer out F/F state to PTO0. - 3) Modulo register (TMOD0) setting. - 4) Count register (T0) read. - 5) Interrupt request flag (IRQT0) setting, clear, and test - (a) Count operation stop mode The count operation stop mode is set when TM0 bit 2 is set to 0. Since count pulse (CP) supply to the count register is stopped, count operation is not performed (b) Count operation mode The count operation mode is set when TM0 bit 2 is set to 1. Count pulses selected by using bits 4 to 6 are supplied to the count register, and count operation is performed as shown in Fig. 5.5–2. Normally, timer operation is started by - 1) setting a count value in the modulo register (TMOD0), then - 2) setting the operation mode, count clock, and start indication in the mode register (TM0). The modulo register is set by using an 8-bit data transfer instruction. Caution: Set a value other than 0 in the modulo register. Example: To set 3FH in channel 0 modulo register. SEL MB15 ; or CLR1 MBE MOV XA, #3FH MOV TMOD0, XA Figure 5.5-5 Operation in Count Operation Mode # 5.5.5 Timer/event counter time setting "Timer setup value" (period) is equal to "modulo register contents + 1" divided by "count pulse frequency" selected by setting the timer mode register. $$T(s) = \frac{n+1}{F_{CP}}$$ : Timer setup value (seconds) F<sub>CP</sub> (Hz) : Count pulse frequency (Hz) : Modulo register value (n ≠ 0) Once the timer is set, an interrupt request signal (IRQT0) is generated at the setup time intervals. Table 5.5-1 lists the resolution and maximum setup value (time when FFH is set in the modulo register) of the timer/event counter for each count pulse. Example: To produce 30 ms time intervals. (f $_{\rm X}=4.194304~{\rm MHz})$ Use the mode with the maximum setup time 62.5 ms. $$\frac{30 \text{ ms}}{244 \,\mu\text{s}} = 122.9 = 7\text{AH}$$ Set 79H in the modulo register. SEL MB15 MOV XA, #79H MOV TMOD0, XA Table 5.5-1 Resolution and Maximum Setup Value (4.19 MHz) | М | ode regist | er | Timer channel 0 | | | | |------|----------------|----|-----------------|--------------------|--|--| | TMO6 | TMO6 TMO5 TMO4 | | Resolution | Maximum setup time | | | | 1 | 0 | 0 | 244 μs | 62.5 ms | | | | 1 | 0 | 1 | 61.1 μs | 15.6 ms | | | | 1 | 1 | 0 | 15.3 μs | 3.91 ms | | | | 1 | 1 1 1 | | 3.81 μs | 977 μs | | | ## 5.5.6 Caution on timer/event counter application ## (1) Error at timer start An error with a maximum length of one clock period of the count pulse (CP) for the value calculated in 5.5.5 occurs in the time until a coincidence signal is generated after the timer starts (TM0.3 is set). This is because clearing of the count register is not synchronized with CP as shown in Fig. 5.5–6. Figure 5.5-6 Error at Timer Starting #### (2) Caution at timer start Normally, the count register T0 and interrupt request flag IRQT0 are cleared when the timer starts (TM0 bit 3 is set). However, if the timer is placed in the operation mode, and IRQT0 setting and timer start occur simultaneously, IRQT0 may be unable to clear. There is no problem when IRQT0 is used for a vectored interrupt. In IRQT0 test application, however, a problem arises such than IRQT0 is set although the timer has been started. Thus, to start the timer at IRQT0 timing, stop the timer once (by setting TM0 bit 2 to 0), then restart it, or start the timer twice. Example: Timer start at IRQT0 timing may be set | | SEL | MB15 | ; | or CLR1 MBE | |----|------|----------|---|-------------| | | MOV | XA, #0 | | | | | MOV | TM0, XA | ; | Timer stop | | | MOV | XA, #4CH | | | | | MOV | TM0, XA | ; | Restart | | or | | | | | | | SEL | MB15 | ; | or CLR1 MBE | | | SET1 | TM0.3 | | | | | SET1 | TM0.3 | : | Restart | ## (3) Error at count register read The count register contents can be read at any time using an 8-bit data memory operation instruction. During execution of the instruction, count pulse change is held and count register change is suppressed. Thus, if the count pulse signal source is input to TIO, count pulses as long as the instruction execution time are deleted. (This symptom does not occur if the internal clock is used for count pulses because they are synchronized with the instruction.) Therefore, if TI0 is input as a count pulse and the count register contents are read, signals having a pulse width that prevents miscount, even if count pulses are deleted, must be input. Since the count hold period in read instruction execution is one machine cycle, the pulse width input to the TI0 pin must be longer than one machine cycle. ## (4) Caution at count pulse change If the timer mode register is rewritten and count pulse change is made, its specification becomes effective immediately after instruction execution. A count pulse (1) or 2 in the timing chart shown below) may occur depending on the clock combination when the count pulse changed. In this case, a miscount may occur or the count register contents may be destroyed. To change count pulse, be sure to set count mode register bit 3 to 1 and restart the timer at the same time. ## (5) Operation after modulo register change The modulo register is changed when an 8-bit data memory operation instruction is executed. If the value appearing after the modulo register is changed and becomes smaller than the count register value, the count register continues counting and overflows, then restarts counting from 0. Thus, if the value after the modulo register is changed (m) and becomes smaller than the value before it was changed (n), the timer must be restarted after the modulo register is changed. ## 5.5.7 Timer/event counter application - (1) Timer 0 is applied to an interval timer generating an interrupt at 50 ms intervals. - The high-order four bits of the mode register are set to 0100B and a maximum setup time of 62.5 ms is selected. - The low-order four bits of the mode register are set to 1100B. - The modulo register setup value is as follows: $$\frac{50 \text{ ms}}{244 \text{ }\mu\text{s}} = 205 = \text{CDH}$$ Example: SEL **MB15** or CLR1 MBE MOV XA, #0CCH : Modulo is set. MOV TMOD0, XA MOV XA, #01001100B MOV TM0. XA : Mode is set and timer is started. : Interrupts is enabled. ΕI ΕI IET0 ; Timer interrupt is enabled. Remarks: In this application, the TIO pin can be used as an input pin. - (2) When the number of pulses input from the TI0 pin reaches 100, an interrupt is generated. (The pulses are active high.) - The high-order four bits of the mode register are set to 0000 and the rising edge is selected. - The low-order four bits of the mode register are set to 1100B. - The modulo register is 99 = 100 1. Example: SEL MB15 ; or CLR1 MBE MOV XA, #100-1 MOV TMOD0, XA ; Modulo is set. MOV XA, #00001100B MOV TM0. XA EI ΕI IET0 : INTT0 is enabled. #### 5.6 Serial Interface ### 5.6.1 Serial interface configuration The μPD7500X has a clocked serial interface (CSI) as shown in Fig. 5.6-2. #### 5.6.2 Serial interface functions The $\mu PD7500X$ serial interface includes the three modes described in (1) to (3) below. Since the serial clock line $\overline{SCK}$ and serial data bus lines SB0/SB1 enable software to determine the output level, any desired transfer format can be handled. - (1) 3-line serial I/O mode - Three lines of serial clock SCK, serial output SO, and serial input SI - Clock synchronous 8-bit send and receive (simultaneous send and receive) - The serial transfer top can be changed between the most and least significant bits (MSB and LSB). - This mode enables the $\mu$ PD7500X to be connected to the $\mu$ PD7500 series, $\mu$ COM-75X family, $\mu$ COM-87 family, and various peripheral I/O devices. - (2) SBI (serial bus interface) mode - This mode conforms to the NEC serial bus format. - Communication can be made with a number of devices by using the serial clock SCK and serial data bus SB0 or SB1 lines. - Address, command, and data can be transferred, and a hardware function for discriminating the signals is included. (See Fig. 5.6-2.) - The acknowledge, busy signal output function and the wake-up function for handshaking are included. Fig. 5.6-1 SBI System Configuration Example ### (3) 2-line serial I/O mode - Communication can be made by using the serial clock SCK and serial data bus SB0 or SB1 lines, - Communication can be made with a number of devices by using software to control the output level to the two lines. Any desired communication format can be handled. II-1-78 ### Figure 5.6-3 SBI Transfer Timing Chart ## 5.6.3 Main register functions # (1) Serial operating mode register (CSIM) The serial operation mode register (CSIM) consists of eight bits that specify the serial interface operating mode, serial clock, wake-up function, etc. CSIM is set using an 8-bit memory operation instruction. The high-order three bits of CSIM can be set bitwise using the bit name. Bit 6 enables bit test only. Data written into the bit becomes invalid. # Example 1: To select $f_x/2^4$ for serial clock, generate a serial interrupt IRQCSI at the end of each serial transfer, and make serial transfer in the SBI mode using the SB0 pin as the serial data bus line. SEL **MB15** or CLR1 MBE MOV MOV CSIM, XA XA, #10001010B CSIM 10001010B ### Example 2: To enable serial transfer conforming to the CSIM contents. SEL ; or CLR1 MBE SET1 CSIE Wake-up function specification bit (WUP): # (a) When WUP=0 IRQCSI is set each time a serial transfer ends. MB15 WUP is set to 0 during normal transfer. ## (b) When WUP = 1 WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register (SVA) value (wake-up state). When the received address is not its own, an unnecessary interrupt will not be generated. The ACK signal is not output either. The SB0 (SB1) pin is placed in a high impedance state independent of the SO the latch state. When the RESET signal is generated, all bits are cleared. Fig. 5.6-4 shows the format of the serial operation mode register. | Address | | | | | | | | | Symbol | |---------|------|-----|-----|-------|-------|-------|-------|-------|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | . 1 | 0 | | | FE0H | CSIE | COI | WUP | CSIM4 | CSIM3 | CSIM2 | CSIM1 | CSIM0 | CSIM | ## Serial clock selection bits (W) | CSIM1 | CSIMO | | SCK pin mode | | | |-------|---------|-----------------------------------------|--------------|--|--| | | CSIIVIO | 3-line serial I/O mode | CON pirmode | | | | 0 | 0 | SCK pin input clock from the ex | Input | | | | 0 | 1 | Timer/event counter output (TC | D) | | | | 1 | 0 | f <sub>X</sub> /2 <sup>4</sup> (262 kH | Output | | | | 1 | 1 | f <sub>X</sub> /2 <sup>3</sup> (524 kH: | i | | | The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. # Serial interface operating mode selection bits (W) | CSIM4 | СЅІМЗ | CSIM2 | Operating mode | Shift register bit order | SO pin function | SI pin function | | | |-------|-------|-------|------------------------|--------------------------------------------------------|---------------------------------------------------|---------------------------------------------------|-----------|---------------------------------------------------| | | | 0 | | SIO <sub>7-0</sub> → XA<br>(transfer starts<br>at MBS) | SO/BO2 | | | | | X | 0 | 1 | 3-line serial I/O mode | SIO <sub>0-7</sub> XA (transfer starts at LSB) | SO/PO2<br>(CMOS output) | SI/PO3<br>(input) | | | | 0 | | | ODI d- | CIOVA | SB0/PO2<br>(N-channel open drain<br>input/output) | PO3 input | | | | 1 | 1 | 0 | SBI mode | SIO <sub>7-0</sub> XA<br>(transfer starts<br>at MSB) | (transfer starts | (transfer starts | PO2 input | SB1/PO3<br>(N-channel open drain<br>input/output) | | 0 | | | 0.11 | 010 45 74 | SB1/PO2<br>(N-channel open drain<br>input/output) | PO3 input | | | | 1 | 1 | 1 | 2-line serial I/O mode | SIO <sub>7-0</sub> XA<br>(transfer starts<br>at MSB) | PO2 input | SBI/PO3<br>(N-channel open drain<br>input/output) | | | (to be continued) Fig. 5.6-4 Serial Operation Mode Register Format ## Wake-up function specification bit (W) | | 0 | IRQCSI is set each time a serial transfer ends in each mode. | |-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WUP | 1 | WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register data (wake-up state). SB0 (SB1) is placed in the high impedance state | Coincidence signal received from address comparator (R (bit test is only enabled)) Note 1, Note 2 | Γ. | COI | 0 | Slave address register and shift register data mismatch. | |----|-----|---|----------------------------------------------------------| | 1 | 501 | 1 | Slave address register and shift register data match. | ## Serial interface operation enable/disable specification bit (W) Note 3 | | | Shift register operation | Serial clock counter | IRQCSI flag | SO/SB0 and SI/SB1 pins | |------|---|------------------------------|----------------------|-------------|------------------------------------------------------| | | 0 | Shift operation is disabled. | Clear | Hold | Port 0 function only | | CSIE | 1 | Shift operation is enabled. | Count operation | Can be set. | Also used for port 0 according to each mode function | Figure 5.6-4 Serial Operation Mode Register Format (cont'd) #### Notes: - 1. COI is only valid before serial transfer starts or after it is complete. An undefined value is read during serial transfer. - 2. Data written into COI is ignored. - 3. To use PO1/SCK pin as an input port, set the following below. - Set CSIM0 and CSIM1 bits to 0. (PO1/SCK pins are set to input mode.) - Set CSIE bit to 0. (Stop the serial interface operation.) When CSIM0=CSIM1=0 and CSIE=1 or CSIM0, CSIM1≠0 and CSIE=0, PO1/SCK pins are output to high level. Remarks: (W): Data write is only enabled. (R): Data read is only enabled. (2) Serial bus interface control register (SBIC) The 8-bit serial bus interface control register (SBIC) consists of the serial bus state control bits and flags indicating the states of input data from serial bus. It is mainly used in the SBI mode. Fig. 5.6–5 shows the SBIC format. SBIC is set or tested by using a bit operation (manipulation) instruction. When the RESET signal is generated, all the SBIC bits are cleared. ## Cautions: - 1. SBIC cannot be set by using 4- or 8-bit memory operation instruction. - 2. In the 3- or 2-line serial I/O mode, use only the following two bits for SO latch control: - (a) Bus release trigger bit (RELT): To set SO latch - (b) Command trigger bit (CMDT): To clear SO latch - 3. For the bus release, command, acknowledge, and busy signals, see 5.6.5 (3). #### Example 1: To output command signal. SEL MB15 ; or CLR1 MBE SET1 CMDT Example 2: To test RELD and CMDD and determine the receive data type for appropriate processing. SEL MB15 SKF RELD ; RELD test BR !ADRS SKT CMDD ; CMDD test BR !DATA CMD: ... ; Command transfer DATA: ... ; Data transfer ADRS: ... ; Address transfer Address Symbol | FE2lus release | 1 BS | | | | | | | | | | |------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------| | us release | | YE | ACKD | ACKE | ACKT | CMDD | RELD | CMDT | RELT | SBIC | | | trigger bit | (W) | | | | | | | | | | RELT | SO latch<br>automat | | | ting the bit. | It is used to | o output bus | release siç | ınal. After S | O latch is s | et, the bit is | | ommand tri | igger bit (\ | <b>N</b> ) | | | | | | | | | | CMDT | | | ared by sett | | It is used to | o output a co | ommand sig | nal. After S | O latch is c | leared, the | | us release | detection | flag (F | 1) | | | | | | | | | RELD | | | | | | | | | | | | | Settin<br>(RELI | ig cond<br>D=1) | dition | | | dress receiss register d | | | ased match | es the | | ommand de | etection fla | ag (R) | | | | | | | | | | CMDD | Clear<br>(CMD | condi<br>D=0) | tion | | When the | e transfer sta<br>e <u>bus rel</u> eas<br>e RESET sig | e signal is d | detected. | | | | | Settin<br>(CMD | g cond | dition | V | /hen the co | mmand sigr | nal is detect | ed. | | | | cknowledge | e trigger b | it (W) | | | | | | | | | | ACKT | | | | | | one clock | period of So | CK | | | | | completi | on | | ır. | nmediatly a | fter execution | on of the se | t instruction | | | | | :<br>is automa<br>: ACKT, se<br>e enable b | atically | Œ to 0.<br>V) | er acknowle | edge signal | is output. | 2. ACKT | cannot be | cleared usi | ng software. | | <ol> <li>ACKT</li> <li>To set</li> </ol> | is automa | atically | E to 0.<br>V)<br>Automatic | er acknowle | edge signal<br>ge signal o | | 2. ACKT | cannot be | cleared usi | | | <ol> <li>ACKT</li> <li>To set</li> </ol> | :<br>is automa<br>: ACKT, se<br>e enable b | atically | E to 0.<br>V)<br>Automatic | er acknowled<br>acknowled<br>lge trigger t | ge signal obit ACKT). | is output. | 2. ACKT | cannot be gnal can be ut during th | cleared usi | setting the | | 1. ACKT<br>3. To set<br>cknowledge | :<br>is automa<br>: ACKT, se<br>e enable b | atically | E to 0. V) Automatic acknowled Before train | acknowled<br>acknowled<br>lge trigger t<br>nsfer | ge signal o bit ACKT). Ackt SCk Ackt imm | is output. utput is disa | 2. ACKT bled (the signal is outpally output I | gnal can be<br>ut during th<br>by presettin<br>ut during or | cleared using output by seen in the clock per instruction | k period of | | 1. ACKT<br>3. To set<br>cknowledge | : is automa ACKT, se e enable b | atically<br>et ACk<br>it (R/V | Automatic<br>acknowled<br>Before trai<br>completion<br>After trans<br>completion | acknowled<br>acknowled<br>lge trigger t<br>nsfer | ge signal o bit ACKT). Ackt SCk Ackt imm | is output. utput is disa nowledge si ( automatic nowledge si ediately after | 2. ACKT bled (the signal is outpally output I | gnal can be<br>ut during th<br>by presettin<br>ut during or | cleared using output by seen in the clock per instruction | k period of | | 1. ACKT 3. To set cknowledge ACKE | : is automa: ACKT, see e enable b | atically<br>et ACk<br>it (R/V | Automatic acknowled Before transcompletion After transcompletion R) | acknowled<br>acknowled<br>gge trigger t<br>nsfer | ge signal o oit ACKT). Ack SCF Acki imm (aut | is output. utput is disa nowledge si ( automatic nowledge si ediately after | 2. ACKT bled (the signal is output la gnal is output la gnal is output execution utput by pressured. | gnal can be<br>ut during th<br>by presettin<br>ut during or | cleared using output by seen in the clock per instruction | k period of | | 1. ACKT<br>3. To set<br>cknowledge | : is automa: ACKT, se e enable b 0 1 c edetection Clea (AC Sett | atically<br>et ACK<br>iit (R/V | Automatic acknowled Before transcompletion After transcompletion R) | acknowled<br>ge trigger the<br>nsfer | ge signal o oit ACKT). Ack SCF Ack imm (aut | is output. utput is disa nowledge si (automatic nowledge si ediately afte omatically o | 2. ACK1 bled (the signal is output lignal is output lignal is output execution utput by pressured. started. input. | gnal can be<br>ut during th<br>by presettin<br>ut during or<br>of the set i<br>esetting AC | cleared using output by seen in the clock per instruction | k period of | | 1. ACKT 3. To set cknowledge ACKE | : is automa ACKT, se e enable b 0 1 c edetection Clea (AC Sett (AC | attically st ACK it (R/V | Automatic acknowled Before train completion After trans completion R) | acknowled<br>ge trigger the<br>nsfer | ge signal o oit ACKT). Ack SCF Ack imm (aut | is output. utput is disa nowledge si ( automatic nowledge si tediately afte omatically o transfer is RESET is | 2. ACK1 bled (the signal is output lignal is output lignal is output execution utput by pressured. started. input. | gnal can be<br>ut during th<br>by presettin<br>ut during or<br>of the set i<br>esetting AC | cleared using output by seen in the clock per instruction | k period of | | 1. ACKT 3. To set cknowledge ACKE | : is automa ACKT, se e enable b 0 1 c edetection Clea (AC Sett (AC | n flag ( ar cono (KD=1)) ing coo (KD=1) | Automatic acknowled Before transcompletion After transcompletion R) dition c (R/W) | acknowled lige trigger that the state of | ge signal ooit ACKT). Ack: SCF Ack: imm (aut When the When the When the aco | is output. utput is disa nowledge si ( automatic nowledge si tediately afte omatically o transfer is RESET is | 2. ACKT bled (the signal is output langual is output langual is output langual is output by presentation of the signal is defined as a control output to t | gnal can be used during the by presettin ust during on of the set i esetting ACI | cleared using output by seen in the clock per nstruction KE to 1). | k period of 1). iod of SCK | | 1. ACKT 3. To set cknowledge ACKE Cknowledge ACKD ynchronous | : is automa ACKT, see e enable b 0 1 e detection Clear (AC Sett (AC | ar concerning consideration of the state | Automatic acknowled Before transcompletion After transcompletion R) dition additions at (R/W) anchronous anchronization | acknowled lige trigger to hister in the second seco | ge signal o oit ACKT). Ack SCF Ack imm (aut When the When the When the ac | is output. utput is disa nowledge si (automatic nowledge si tediately afte omatically o tetransfer is RESET is cknowledge si | 2. ACKT bled (the signal is output land) gnal is output land) gnal is output execution utput by presented. input. signal is definitional is defined. | gnal can be used during the by presettin ust during on of the set i esetting ACI | cleared using output by seen inth clock grant and a clock per enstruction (KE to 1). | k period of 1). iod of SCK | Figure 5.6-6 RELT, CMDT, RELD, CMDD Operation Set after transfer completion Figure 5.6-7 ACKT Operation Figure 5.6-8 ACKE Operation falling edge. Figure 5.6-10 BSYE Operation ## (3) Slave address register (SVA) When the $\mu$ PD7500X is connected to the serial bus as a slave device in the SBI mode, the 8-bit slave address register (SVA) is used to set the slave address of the $\mu$ PD7500X. The SVA value is compared with received 8-bit data by the address comparator. If a match is found between them, serial operating mode register (CSIM) bit 6 (COI) is set to 1. If a match is not found when the address is received, the bus release detection flag (RELD) is cleared. When WUP = 1, IRQCSI is set only if a match is found (wake-up is detected). This interrupt request can be used to know that a communication request is sent from the master to $\mu$ PD7500X. SVA can also be used to detect an error when the $\mu PD7500X$ sends address, command, or data as a master device. (See 5.6.6.) SVA is set using an 8-bit memory operation instruction. It can only be written. When the RESET signal is generated in a mode which is not standby, the SVA value becomes undefined. ## 5.6.4 Signals in SBI mode Tables 5.6-1 and 5.6-2 list the signals used in the SBI mode. ### Table 5.6-1 Signals in SBI Mode (I) | Signal name | Output<br>device | Definition | Timing chart | Output<br>condition | Flag<br>influence | Explaination | |----------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | Bus release<br>signal<br>(REL) | Master | SB0 ( <u>SB1</u> ) rising edge when SCK = 1 | (Figure 1) | RELT is set. | • RELD is set. • CMDD is cleared. | The signal is followed by CMD signal output indicating that the send data is an address | | Command<br>signal<br>(CMD) | Master | SB0 (SB1) falling<br>edge when SCK = 1 | (Figure 2) | CMDT is set. | • CMDD is set. | i) After REL signal is<br>output, send data<br>is an address.<br>ii) When REL signal is<br>not output, send<br>data is a command. | | Acknowledge<br>sign <u>al</u><br>(ACK) | Slave | Low signal output to SB0 (SB1) during one clock period of SCK after completion of serial reception | (Figure 3) | 1 ACKE = 1<br>2 ACKT is<br>set. | • ACKD is set. | Completion of reception | | Bus <u>y sign</u> al<br>(BUSY) | Master/<br>Slave | (Synchronous busy<br>signal)<br>Low signal output to<br>SB0 (SB1) following<br>acknowledge signal | | • BSYE = 1 | | Serial reception cannot<br>be done because<br>processing is being<br>performed. | | | - | (Asynchronous busy signal) Low signal output to SB0 (SB1) (except during serial transfer). It is not synchronized with SCK. | | CMDT is set. | <u>-</u> | | | Ready signal<br>(READY) | Slave | High signal output to<br>SB0 (SB1) before<br>start or after completion<br>of serial transfer | | 1 BSYE = 0<br>2 Execution<br>of SIO data<br>write instruc-<br>tion (transfer<br>start indication) | | Serial reception can be done. | Table5.6-2 Signals in SBI Mode (II) | Signal name | Output<br>device | Definition | Timing chart | Output condition | Flag<br>influence | Explanation | |--------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------| | Se <u>rial cl</u> ock<br>(SCK) | Master | Synchronous clock to output address, | (Figure 4) | Execution of<br>SIO data write<br>instruction<br>when CSIE =1<br>(serial transfer<br>start<br>indication)<br>(Note 2) | IRQCSI is<br>set (on the<br>rising edge<br>of ninth<br>clock).<br>(Note 1) | Signal output timing<br>to serial data bus | | Address<br>(A7–0) | Master | 8-bit data transferred<br>in synchronization<br>with SCK after REL<br>and CMD signals are<br>output. | (Figure 5) | | (Note 1) | Slave device address<br>value on serial bus | | Command<br>(C7-0) | Master | 8-bit data transferred in synchronization with SCK after CMD signal only is output (REL signal is not output). | (Figure 6) | | None | Indication message<br>sent to slave device | | Data<br>(D7–0) | Master<br>or<br>Slave | 8-bit data transferred<br>in synchronization<br>with SCK when neither<br>REL nor CMD signal<br>is output. | (Figure 7) | | None | Numeric data<br>processed by slave<br>or master device | Notes: 1. When WUP = 0, IRQCSI is always set on the ninth clock $\overline{SCK}$ rising edge. When <u>WUP</u> = 1, IROCS is set only when the received address matches the value in the slave address register (SVA). 2. In the <u>BUSY</u> state, transfer is started after the READY state is set. #### 5.6.5 Serial interface operation The serial interface includes the following four operating modes. - Operation stop mode - 3-line serial I/O mode - SBI mode - 2-line serial I/O mode **Table 5.6-3 Serial Interace Operation Mode** | | | · • | | |-------|-------|-------|-------------------| | CSIM7 | CSIM3 | CSIM2 | Operating mode | | 0 | - 1 | _ | Operation stop | | 1 | 0 | i - | 3-line serial I/O | | 1 | 1 | 0 | SBI mode | | . 1 | : 1 | - 1 | 2-line serial I/O | ## (1) Operation stop mode When CSIE = 0, the serial interface is placed in the operation stop mode. In this mode, no serial transfer is done. The operation stop mode is set when the serial interface is not used, so that the power consumption is reduced. In this mode, the shift register does not perform shift operations and can be used as a normal 8-bit register. All the P01/SCK, P02/SO/SB0, and P03/SI/SB1 pins are placed in the high impedance state and used only for the input port function. The P01/SCK pin is placed in the state listed in Table 5.6-4 according to how CSIM1 and CSIM0 are set. Table 5.6-4 CSIM1 and CSIM0 Settings | CSIM1 | CSIM0 | Serial clock | P01/SCK pin state | |-------|-------|----------------|------------------------------------------| | 0 | 0 | External clock | High impedance | | 0 | 1 | | A high level is output. | | 1 | 0 | Internal clock | However, a serial clock is output during | | 1 | 1 1 | | serial transfer. | Note: For the serial clock, see Fig. 5.6-4. When the RESET signal is generated, the operation stop mode is set. # (2) 3-line serial I/O mode The 3-line serial I/O mode is compatible with the mode used by the $\mu$ PD7500 series or other $\mu$ COM-75X family devices. Fig. 5.6-11 shows the 3-line serial I/O mode operation timing. Serial transfer start is indicated by executing an instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. Fig. 5.6-11 3-line Serial I/O Mode Timing In this mode, shift register shift operation is performed in synchronization with the serial clock (SCK) falling edge, and send data is held in the SO latch and output from the SO pin. The receive data input to the SI pin is latched in the shift register on the rising edge of SCK. Since the SO pin is used as a CMOS output and outputs the SO latch state, the SO pin output state can be handled by setting the RELT and CMDT bits. However, do not try to change it during serial transfer. The SCK pin output state can be controlled if the P01 output latch is operated in the output mode (internal clock mode), as described in 5.6.7. A serial clock can be selected from among four clocks, as listed in Table 5.6-5, by setting the mode register. Normally, shift operation is started by: - 1) Setting the operating mode and serial clock selection data in the mode register (CSIM) - 2) Setting transfer data in the shift register (SIO) (serial operation is started by executing the SIO data write instruction) Serial transfer automatically stops at the end of 8-bit transfer, and the interrupt request flag (IRQCSI) is set. Table 5.6-5 Serial CLock Selection and Application | Mode register | | | Serial clock | Timing at which shift register can be | Application | |---------------|-----------|--------------------------------|---------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------| | CSIM<br>1 | CSIM<br>0 | Source | Serial clock mask | Serial clock mask read/written and serial transfer can be started | | | 0 | 0 | External SCK | Automatic mask | Only when serial transfer stops or SCK is high. | Slave CPU | | 0 | 1 | TOUT F/F | at the end of 8-bit<br>data transfer. | (Note) | Half-duplex<br>asynchronous<br>transfer (under<br>software control) | | 1 | 0 | f <sub>X</sub> /2 <sup>4</sup> | | | Medium-speed serial transfer | | 1 | 1 | f <sub>X</sub> /2 <sup>3</sup> | | | High-speed<br>serial transfer | Note: The serial transfer stops in the opertaion stop mode or when the serial clock is masked after 8-bit transfer has been made. The shift register is read and written using 8-bit transfer instructions. At that time, LSB and MSB can be inverted by setting CSIM bit 2. This function enables the transfer top bit to be changed between LSB and MSB. ## Example: At the same time RAM data specified in the HL register pair is transfered to SIO, the SIO data is read into the accumulator, and serial transfer is started. MOV XA, @HL ; Send data is taken out of RAM. SEL MB15 ; or CLR1 MBE XCH XA, SIO ; Send data and receive data are exchanged, and transfer is started. #### Caution: The transfer top bit LSB or MSB is selected by changing the bit order in writing data into the shift register. The shift order of the shift register bit is always the same. Thus, even if the transfer top bit is changed (LSB to MSB or MSB to LSB) after data is written into the shift register, the data is transferred in the bit order specified before the transfer top bit is changed. Fig. 5.6-12 3-line I/O Mode Format #### (3) SBI mode The SBI mode enables the µPD7500X to communicate with a number of devices by using the $\overline{SCK}$ and SB0 or SB1 lines. Figs. 5.6-13 to 5.6-15 show the timing of operations according to the type of data to be transferred. In the SBI mode, indication of serial transfer start is also given by executing the instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. Shift register shifting is made in synchronization with the serial clock (SCK) falling edge, and send data is held in the SO latch and output from the SB0/P02 or SB1/P03 pin starting at MSB. Receive data input to the SB0 or SB1 pin is latched in the shift register on the rising edge of SCK. The SB0 or SB1 pin specified for the serial data bus is used as N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off. By writing FFH into SIO and shifting it, the N-channel transistor can always be turned off during transfer. When the wake-up function specification bit (WUP) is set to 1, however, the N-channel transistor is always turned off, and FFH need not be written into SIO before reception. Fig. 5.6-13 SBI Mode Timing (Address Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.6-14 SBI Mode Timing (Command Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.6-15 SBI Mode Timing (Data Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. # (4) 2-line serial I/O mode The 2-line serial I/O mode is used for communications using the SCK and SB0 or SB1 lines. The mode can handle any desired communication format by using software to control the SCK and SB0 or SB1 pin output levels. Fig. 5.6-16 shows the 2-line serial I/O mode timing. Serial transfer start indication is given by executing the instruction writing data into the shift register (SIO), MOV or XCH. Be sure to give start indication when CSIE = 1. Shift register shifting is done in synchronization with the falling edge of the serial clock (SCK), and send data is held in the SO latch and output from the SB0/P02 or SB1/P03 pin starting at MSB. Receive data input from the SB0 or SB1 pin is latched in the shift register on the SCK rising edge. The SB0 or SB1 pin specified for the serial data bus is used as an N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off, thus FFH is previously written into SIO. Since the SB0 or SB1 pin outputs the SO latch state, the SB0 or SB1 pin output state (high impedance or low level) can be controlled by setting the RELT and CMDT bits. However, <u>do not</u> change it during serial transfer. In the output mode (internal clock mode), the $\overline{\text{SCK}}$ pin output state can also be controlled by using the P01 output latch, as described in 5.6.7. Fig. 5.6-16 2-line Serial I/O Mode Timing ### 5.6.6 Error detection Since the data of the sending serial bus SB0 or SB1 is also read by the shift register SIO of the device which sends data in the SBI or 2-line serial I/O mode, a send error can be detected as described below: (1) SIO data comparison before the start of a send and after the end of a send If both the pieces of data do not match, it is determined that a send error occurred. (2) Use of slave address register (SVA) Send data is also set in SVA. After the completion of a send, the COI bit (coincidence signal from the address comparator) in the serial operating mode register is tested. If the bit is set to 1, it is determined that normal sending has been performed; if 0, it is determined that a send error has occurred. # 5.6.7 SCK pin output handling MOV CSIM, XA The SCK/P01 pin, which incorporates an output latch, can also produce static output by software control in addition to a normal serial clock. The number of $\overline{SCK}$ s can be set as desired by using software to control the P01 output latch (the SO/SB0, and SI/SB1 pins are controlled by setting the RELT and CMDT bits). The SCK/P01 pin output control method is described below: - (1) The serial operation mode register (CSIM) is set (SCK pin: Output mode, serial operation: Enabled). SCK is set to 1 when serial transfer stops. - (2) The P01 output latch is controlled by using bit manipulation (operation) instructions. Example: To output one clock pulse of SCK by using software. SEL MB15 ; or CLR1 MBE MOV XA, #10000011B ; SCK (f<sub>2</sub>/2<sup>3</sup>), output mode CLR1 0FF0H.1 ; SCK/P01 → 0 SET1 0FF0H.1 ; SCK/P01 1 Fig. 5.6-17 SCK/P01 Pin Configuration The P01 output latch is mapped in address FF0H bit 1. When the RESET signal is generated, the P01 output latch is set to 1. ## Cautions: - 1. The P01 output latch must be set to 1 during normal serial transfer. - 2. Do not use "PORT0.1" to specify the P01 output latch address. Write directly the address (FF0H.1) in operand. At that time, set MBE to 0, or set MBE to 1 and MBS to 15. ### 5.6.8 Serial interface application The serial interface for each mode is explained using examples of applications. The normal serial interface communication sequence is as follows: - 1) Set transfer mode. (Set data in CSIM.) - 2) Write data into SIO and give transfer start indication. (MOV SIO, XA or XCH XA, SIO. At that time, automatic transfer start indication is given.) - 3) After checking that the serial interrupt routine or interrupt request flag (IRQCSI) is set, read receive data, and start transfer. The SBI mode communication sequence is explained in detail in (3) below. - (1) 3-line serial I/O mode - (a) To transfer data starting at MBS using transfer clock of 262 kHz (at 4.19 MHz) (master operation). Example: CLR<sub>1</sub> MBE MOV XA. #10000010B MOV CSIM. XA : Transfer mode is set. MOV XA. TDATA ; TDATA is the transfer data storage address. MOV SIO, XA : Transfer data is set. : Transfer is started. ## Caution: At the second time or after, transfer can be started by setting data in SIO (MOV SIO, XA or XCH XA, SIO). In this application example, the µPD7500X SI/SB1 pin can be used for input. (b) To transfer data starting at the LSB using external clock (slave operation). (In this example, the shift register read/write function to invert the LSB and MSB is used effectively.) Example: Main routine > MBE CLR1 XA, #84H MOV MOV CSIM, XA MOV XA, TDATA MOV SIO, XA : Transfer data is set. : Transfer is started. ΕI **IECSI** EI Interrupt routine (MBE = 0) MOV XA, TDATA XCH XA, SIO ; Receive data - send data, transfer start MOV RDATA, XA ; Receive data is saved. RETI ; Serial operation stop, LSB/MSB inversion mode, external clock (c) To transfer data at a high speed using a transfer clock of 524 kHz (at 4.19 MHz). Example (master) CLR1 MBE MOV XA, #10000011B MOV CSIM, XA ; Transfer mode is set. MOV XA, TDATA MOV SIO, XA : Transfer data is set, Transfer is started. LOOP: SK SKTCLR IRQCSI : IRQCSI is tested. BR LOOP MOV XA, SIO ; Receive data is read. ## (2) 2-line serial I/O mode The serial bus is formed and a number of devices are connected. #### Example: The example system consists of the $\mu$ PD7500X as the master and $\mu$ PD75004, $\mu$ PD7519H, and $\mu$ PD7225G connected as slaves. To form a serial bus as in this example, FFH is previously written into the shift register, a high level is output to the shift register, a high level is output to the SO pin, the output buffers are turned off, and the bus is released except when the SI and SO pins are connected for serial data output. Since the $\mu$ PD7519H SO pin cannot be placed in the high impedance state, a transistor is connected for open collector output, as shown in the diagram above. At the time of data input, the transistor is turned off by previously writing 00H into the shift register. The data output timing by the microcomputers is predetermined. The serial clock is output by the master microcomputer µPD7500X; all other slave microcomputers operate on external clocks. ## (3) SBI mode An application example of serial data communication in the SBI mode is given. In the example, the $\mu PD7500X$ can operate as a master or a slave CPU. The master can also be changed by using a command. ### (a) Serial bus configuration The serial bus configuration in the application example given here assumes that the µPD7500X is connected to bus lines as one device in the serial bus. The following two μPD7500X pins are used: Serial data bus SB0 (P02/SO) and serial clock SCK (P01). Fig. 5.6-18 shows an example of a serial bus configuration. Fig. 5.6-18 Serial Bus Configuration Example ### (b) Command explanation Command types The application example uses the following commands: - - Data is transferred from slave to master. - 2) WRITE: - Data is transferred from master to slave. - 3) END: WRITE command completion is reported to slave. - 4) STOP: - - WRITE command stop is reported to slave. - 5) STATUS: - The slave state is read. - 6) RESET: - The current slave being selected is made unselected. - 7) CHGMST: The master authorization is transferred to the slave. ### Communication sequence The communication sequence between the master and slave is as follows: - 1) Communication is started by the master, which sends the address of the slave to communicate with and selects the slave (chip select). - The slave which receives the address returns $\overline{ACK}$ and communicates with the master. (The slave is placed in selected state.) - 2) Command and data are transferred between the slave selected in 1 and the master. - Since command and data are transferred point-to-point (between the master and specific slave), other slaves must be deselected. - 3) Communication terminates when the slave is deselected in either of the following cases: - When the master sends the RESET command, the selected slave is deselected. - If the master is changed by using the CHGMST command, the device changed from master to slave is deselected. Command format The command transfer formats are shown below: 1) READ command The READ command reads data from a given slave. The read data count ranges from one to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave Fig. 5.6-19 READ Command Transfer Format After receiving the data count, the slave returns $\overline{ACK}$ if the number of $\underline{data}$ bytes that can be sent is greater than the data count. If it is less than the data count, the slave does not return $\overline{ACK}$ , resulting in an error. During data transfer, the slave compares the SIO contents before and after data transfer to check that data has been output to the bus normally. If the SIO contents before and after transfer do not match, the slave does not return ACK, resulting in an error. 2) WRITE, END, and STOP commands The WRITE, END, and STOP commands are used to write data into a particulary slave. The write data count ranges from 1 to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave ### Fig. 5.6-20 WRITE, END Command Transfer Format After receiving the data count, the slave returns ACK if the receive data store area is larger than the data count. If it is less than the data count, it does not return ACK, resulting in an error. At the termination of all data transfer, the master sends the END command to the slave. It signals that all data has been transferred normally. The slave also receives an END command before it completes all data reception. In this case, the data which has been received immediately before the END command is received becomes valid. During data sending, the master compares the SIO contents before and after data sending to check that data has been output to the bus normally. If the SO contents before and after sending do not match, the master sends the STOP command and stops data transfer. - M: Output by master - S: Output by slave Fig. 5.6-21 STOP Command Transfer Format When receiving the STOP command, the slave invalidates the 1-byte data received immediately before receiving the STOP command. 3) STATUS command The STATUS Command Transfer Format - M: Output by master - S: Output by slave Fig. 5.6-22 STATUS Command Status Format Fig. 5.6-23 shows the format of the status returned by the slave. Fig. 5.6-23 STATUS Command Status Format To send status data, the slave compares the contents before and after sending status data. If they do not match, the slave does not return ACK, resulting in an error. ## 4) RESET command The RESET command is used to cause the currently selected slave to be selected. When the RESET command is issued, all slaves can be deselected. M: Output by master S: Output ba slave ### Fig. 5.6-24 RESET Command Transfer Format ### 5) CHGMST command The CHGMST command transfers the master authorization to the currently selected slave. M: Output by master S: Output by slave Fig. 5.6-25 CHGMST Command Transfer Format When receiving the CHGMST command, the slave decides whether or not it can receive the master authorization, and returns either of the following data to the master: - 0FFH: Master change is enabled. - 00H : Master change is disabled. When transferring data, the slave compares the SIO contents before and after data transfer. If they do not match, the slave does not return $\overline{ACK}$ , resulting in an error. If no error occurs, the master serves as a slave after 0FFH data sending is complete. If no error occurs, the slave serves as the master after 0FFH data sending is completed. #### Error occurrence When a communication error occurs, the master and slave operate as explained below: The slave informs the master of error occurrence by returning no ACK. When an error occurs, the status bit (bit 2) indicating error occurence is set to 1 and all command processing being performed is cancelled.\_\_\_\_ After completing the sending or receiving of one byte, the master checks whether or not ACK is returned from slave. If ACK is not returned from slave within a given period after sending or receiving is completed, the master decides that an error has occurred and outputs a dummy ACK signal. Fig. 5.6-26 Master and Slave Operation when Error Occured The following errors are possible: - Errors that may occur in the slave - 1) Command transfer format is erroneous. - 2) Undefined command is received. - 3) The number of data bytes to be transferred (data count) is insufficient during READ command execution, - 4) Data storage area is insufficient during WRITE command execution. - 5) When READ, STATUS, or CHGMST command data is sent, data changes. When any error in 1) or 5) occurs, no ACK is returned. - Errors that may occur in the master When WRITE command data is sent, if data changes, STOP command is sent to the slave. ### 5.7 Bit Sequential Buffer - 16 Bits The bit sequential buffer is a special data memory for bit manipulation. Bit manipulation can be easily performed by changing address and bit specification in sequence. The buffer is useful for bitwise processing of long data. The data memory consists of 16 bits. pmem.@L addressing of bit manipulation is enabled; indirect bit specification can be made by using the L register. Simply by incrementing or decrementing the L register in a program loop, processing can be performed while the specified bits are being moved in sequence. Fig. 5.7-1 Bit Sequential Buffer Format ### Remarks: In pmem.@L addressing, specified bits are moved according to the L register. Data can also be handled in direct addressing. The 1-, 4--, and 8-bit direct addressing modes and pmem.@L addressing mode can be used in combination for continuous input and output of 1-bit data. In 8-bit manipulation, BSB0 and BSB2 are specified, and data is handled every high-order eight and low-order eight bits. #### Example: To output 16-bit data in BUFF 1 and BUFF2 from port 3 bit 0 serially. CLR<sub>1</sub> MBE MOV XA. BUFF1 MOV BSB0, XA : BSB0 and BSB1 are set. MOV XA. BUFF 2 MOV BSB2, XA ; BSB2 and BSB3 are set. MOV L. #0 LOOP: SKT BSB0, @L ; BSB-specified bit is tested. BR LOOP1 NOP ; Dummy (timing adjustment) PORT3.0 SET<sub>1</sub> ; Port 3 bit 0 is set. BR LOOP2 LOOP1: CLR1 PORT3.0 : Port 3 bit 0 is cleared. NOP ; Dummy (timing adjustment) NOP LOOP2: INCS ; L- L+1 BR LOOP RFT ### **CHAPTER 6 INTERRUPT FUNCTION** The $\mu PD7500X$ contains six vectored interrupt sources and two testable inputs for versatile application. The µPD7500X interrupt control circuit has the following features to enable very high-speed interrupt service: - (a) Whether or not interrupts can be acknowledged can be controlled by using enable flag (IEXXX). - (b) The interrupt service start address and MBE during interrupt service can be set as desired by using a vector table. Starting the actual interrupt service program is fast. - (c) Interrupt request flag (IRQXXX) can be tested and cleared. Interrupt occurrence can be checked by using software. - (d) The standby mode (STOP or HALT) can be released by making an interrupt request. A backup release source is available by using the interrupt enable flag. ## 6.1 Interrupt Control Circuit Configuration Fig. 6.1-1 shows configuration of the interrupt control circuit. The hardware devices are mapped in data memory. Fig. 6.1-1 Interrupt Control Circuit Block Diagram II-1-106 ## 6.2 Interrupt Source Types and Vector Table Table 6.2-1 lists the types of interrupt sources for the μPD7500X. Fig. 6.2-1 shows the interrupt vector table. Table 6.2-1 Interrupt Source Types | | Interrupt source | Internal<br>/external | Interrupt priority (Note 1) | Vectored interrupt request signal (vector table address) | |--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-----------------------|------------------------------------------------|----------------------------------------------------------| | INTBT<br>(reference | time interval signal from basic interval timer) | Internal | 1 | VRQ1 (0002H) | | INT4<br>(both rising | and falling edge detection) | External | | | | INTO | (selection of rising or falling edge detection) | External | 2 | VRQ2 (0004H) | | INT1 | | External | 3 | VRQ3 (0006H) | | INTCSI<br>(serial data | transfer end signal) | Internal | 4 | VRQ4 (0008H) | | INTTO (coincidence signal between programmable timer/ counter count register and modulo register) | | Internal | 5 | VRQ5 (000AH) | | INT2<br>(rising edge detection of input to INT2 pin or falling edge<br>detection of any input to KR0-KR7) (Note 2) | | External | Testable input signals (IRQ2 and IRQW are set) | | | INTW<br>(signal from | n watch timer) | Internal | | | Note 1: The interrupt priority indicates the priority given to each interrupt when more than one interrupt request occurs at the same Note 2: For details of INT2, see 6.3 (2). ## Address | 002H | MBE | 0 | 0 | 0 | INTBT/INT4 start address (high-order four bits) | |------|-----|---|---|---|-------------------------------------------------| | | | | | | INTBT/INT4 start address (low-order eight bits) | | 004H | MBE | 0 | 0 | 0 | INT0 start address<br>(high-order four bits) | | | - | | | | INT0 start address<br>(low-order eight bits) | | 006H | MBE | 0 | 0 | 0 | INT1 start address<br>(high-order four bits) | | | | | | | INT1 start address<br>(low-order eight bits) | | H800 | MBE | 0 | 0 | 0 | INTCSI start address<br>(high-order four bits) | | | | | | | INTCSI start address<br>(low-order eight bits) | | 00AH | MBE | 0 | 0 | 0 | INTT0 start address<br>(high-order four bits) | | | | | | | INTT0 start address<br>(low-order eight bits) | Fig. 6.2-1 Interrupt Vector Table (a) μPD75004 | Address | | | | | |---------|-----|---|---|-------------------------------------------------| | 002H | MBE | 0 | 0 | INTBT/INT4 start address (high-order five bits) | | | | | | INTBT/INT4 start address (low-order eight bits) | | 004H | MBE | 0 | 0 | INT0 start address (high-order five bits) | | | | | | INT0 start address (low-order eight bits) | | 006H | MBE | 0 | 0 | INT1 start address (high-order five bits) | | | | | | INT1 start address (low-order eight bits) | | H800 | MBE | 0 | 0 | INTCSI start address (high-order five bits) | | | - | | | INTCSI start address (low-order eight bits) | | 00AH | MBE | 0 | 0 | INTT0 start address (high-order five bits) | | | | | | INTT0 start address<br>(low-order eight bits) | | | | | | | Fig. 6.2-1 Interrupt Vector Table (b) μPD75006, μPD75008 The interrupt priority in Table 6.2-1 indicates the interrupt execution order when a number of interrupt requests occur at the same time or are held. The interrupt service start addresses and MBE setup values during interrupt service are written into the vector table. The vector table is set by using an assembler pseudo-instruction (VENTn). Example: To set INTBT/INT4 in vector table 2 Vector table 2 MBE setup value in address 0002. interrupt service routine. 3 Always set RBE to 0. 3 GOTOBT 4 This symbol denotes the interrupt service routine start address. Caution 1: The vector table address specified in VENTn (n=1-5) becomes 2n address. Caution 2: Always set RBE to 0 in VENTn. Example: To set INTBT/INT4 and INTT0 in vector table. VENT1 VENT5 MBE=0, RBE=0, GOTOBT MBE=0, RBE=0, GOTOT0 # 6.3 Hardware Devices of Interrupt Control Circuit (1) Interrupt request and enable flags The interrupt request flag (IRQXXX) is set to 1 when a given interrupt request occurs; it is automatically cleared when interrupt service is executed. Although IRQBT and INT4 share the vector address, they differ in clear operation. (See 6.6.) An interrupt enable flag (IEXXX) is provided for each interrupt request flag. An interrupt is enabled when the corresponding interrupt enable flag is set to 1 and disabled when the flag is set to 0. When the interrupt request flag is set, and the interrupt enable flag enables an interrupt, a vectored interrupt request (VRQn) occurs. This signal is also used to release the standby mode. The interrupt request and enable flags are handled by using the bit manipulation and 4-bit memory operation instructions. The flags can be directly handled by using the bit manipulation instruction regardless of how MBE is set. The interrupt enable flags are handled by using the EI IEXXX and DI IEXXX instructions. Normally, the interrupt request flags are tested by using the SKTCLR instruction. Example: IFO : INT0 is enabled. DI IE1 : INT1 is disabled. SKTCLR FI IROCSI : If IRQCSI is set to 1, skip and clear. If the interrupt request flag is set by using the instruction, a vectored interrupt is executed as if an interrupt occured although it did not actually occurs. When the RESET signal is generated, the interrupt request and enable flags are cleared, and all interrupts are disabled. Table 6.3-1 Interrupt Request and Enable Flags | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | IRQBT | Is set by reference time interval signal generated by the basic interval timer | IEBT | | IRQ4 | Is set when either the rising or falling edge of the INT4/P00 pin input signal is detected. | IE4 | | IRQ0 | Is set when the INT0/P10 pin input signal edge is detected. Detected edge is selected among rising and falling edges by using the INT0 mode register (IM0). | IE0 | | IRQ1 | Is set when the edge of the INT1/P11 pin input signal is detected. Detected edge is selected from rising and falling edges by using the INT1 mode register (IM1). | IE1 | | IRQCSI | Is set by serial data transfer end signal on serial interface. | IECSI | | IRQT0 | Is set by coincidence signal from timer/event counter 0. | IET0 | Table 6.3-1 Interrupt Request and Enable Flags (cont'd) | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | IRQW | Is set by signal from the watch timer. | IEW | | IRQ2 | Is set when the rising edge of the INT2/P12 pin input signal is detected or the falling edge of any input to the KR0/P60 to KR7/P73 pins is detected. | IE2 | (2) Noise eliminator and edge detection mode registers. Figs. 6.3-1 and 6.3-2 show the relationship of INT0 and INT1, INT2 and KR0-KR7 pins, respectively, within the interrupt control circuit. They are used for inputting external interrupts in cases where noise can be eliminated by the sampling clock and the detected edge can be selected. Any pulse narrower than the sampling clock is determined to be a noise pulse and is eliminated by the noise eliminator. A pulse twice as wide (or more) as the sampling clock is acknowledged as a valid interrupt signal. For INTO the sampling clock can be changed to two stages. Note that when the INTO pin is used for P10 (port pin), the signal is also input via the noise eliminator. Caution: Since INT0 sampling uses clock, INT0 does not operate at standby mode. IRQ2 is set in either of the following modes: - (a) When the rising edge of INT2 pin input is detected, IRQ2 is set. - (b) When the falling edge of any input to KR0-KR7 pins is detected: When the falling edge of any input to pins selected among KR0-KR7 by using the edge detection mode register (IM2) is detected, IRQ2 is set. For example, if KR4-KR7 are selected, IRQ2 is set if the falling edge is input to any one of KR4-KR7, because KR4-KR7 inputs are ANDed in the $\mu$ PD7500X. Fig. 6.3-4 shows the format of the edge detection mode registers used to select detected edge (IM0 to IM2). IM0 to IM2 are set individually by using a 4-bit memory operation instruction. When RESET signal is generated, all the register bits are cleared; INT0, INT1, and INT2 detection edges are specified to rising edges. Fig. 6.3-1 INT0 and INT1 Configuration Fig. 6.3-2 INT2 and KR0-KR7 Configuration When a high level is input successively, the noise eliminator outputs a high level; when a low level is input successively, it outputs a low level. Fig. 6.3-3 Noise Eliminator Input/Output Timing Caution: If the edge detection mode register is changed, the interrupt request flag may be set. Disable interrupts beforehand, and change the mode register. Clear the interrupt request flag by using the CLR1 instruction before enabling interrupts. If f<sub>x</sub>/64 is selected for the sampling clock in an IM0 change, clear the interrupt request flag within 16 machine cycles after the mode register is changed. Fig. 6.3-4 Edge Detection Mode Register Format ## (3) Interrupt master enable flag (IME) Interrupt master enable flag enables or disables acknowledgement of all interrupts. IME is set to 1 or to 0 by using the El and Dl instructions. When the RESET signal is generated, IME is cleared, disabling acknowledgement of all interrupts. #### Address Fig. 6.3-5 IME Format ## (4) Interrupt status flag The interrupt status flag (IST0) indicates the current status of processing being performed by CPU; it is contained in the PSW. The interrupt control circuit controls multi-interrupts (as listed in Table 6.3-2) according to the contents of interrupt status flag. Since IST0 can be changed by using a 4-bit or a one-bit manipulation instruction, multi-interrupt can also be implemented by changing the status of processing being performed. Multi-interrupt can always be implemented regardless of the MBE setting when IST0 is handled bitwise. Be sure to execute the DI instruction to disable interrupts before handling IST0 and the EI instruction to enable interrupts after handling IST0. When an interrupt is acknowledged, IST0 is saved in stack memory together with other PSW bits, then it is automatically set to 1. When the RETI instruction is executed, the former IST0 value (0) is restored. When the RESET signal is generated, the flag is cleared. ### Table 6.3-2 ISTO and Interrupt Service State | IST0 | Status of<br>processing | CPU processing contents | Interrupt requests that<br>can be acknowledged | After interrupt is acknowledged | |------|-------------------------|----------------------------------|------------------------------------------------|---------------------------------| | | | | | IST0 | | 0 | Status 0 | During normal program processing | All interrupts can be acknowledged. | 1 | | 1 | Status 1 | During interrupt service | None of the interrupts can be acknowledged. | _ | ### 6.4 Interrupt Sequence When an interrupt occurs, it is processed as shown in Fig. 6.4-1. Remarks: 1. IST0: Interrupt status flag (PSW bit 2). (See Table 6.3-2) 2. Store the interrupt service program start addresses and MBE setup values at the interrupt start in the vector table. Fig. 6.4-1 Interrupt Service Flow ### 6.5 Multi-interrupt Service Control The µPD7500X enables multi-interrupts as described below. As understood from Table 6.3-2, multi-interrupt is enabled if the interrupts status flag is changed by a program. That is, multi-interrupt is enabled if IST0 is changed to 0 by the interrupt service program setting status 0. To change IST0, execute the DI instruction beforehand to disable interrupts. Fig. 6.5-1 Multi-Interrupt by Changing Interrupt Status Flag ## 6.6 Vector Address Share Interrupt Service Since INTBT and INT4 interrupt sources share the vector table addresses, interrupt source selection is made as described below: (1) To use one interrupt only Set the interrupt enable flag to 1 for the required one of the two interrupt sources sharing the vector table addresses, and clear the interrupt enable flag of the other interrupt source. In this case, an interrupt request is generated from the interrupt source corresponding to the interrupt enable flag that is set to 1 (IEXXX = 1). When the interrupt request is acknowledged, the interrupt request flag is cleared. (2) To use both interrupts Set both the interrupt enable flags of the two interrupt sources to 1. In this case, an interrupt request is made by ORing the interrupt request flags of the two interrupt sources. Even if an interrupt request is acknowledged when either or both of the interrupt request flags are set to 1, the interrupt request flags are not reset. Therefore, the interrupt service routine must decide which interrupt source the interrupt is generated from. This is accomplished by executing the SKTCLR instruction to check the interrupt request flags. If both the interrupt request flags are set to 1 when the request flags are tested and cleared by execution of the SKTCLR instruction, the interrupt request is left even if one request flag is cleared. If IST0 is cleared, dual interrupt service is entered according to the left interrupt request. Remarks: When only one interrupt is enabled, the source of an interrupt is known. Thus, the interrupt request flag is cleared by hardware when interrupt is acknowledged. When both interrupts are enabled, the source of an interrupt is not defined; thus, interrupt request flag cannot be cleared by hardware. Software is used to check the interrupt request flags and determine the interrupt source. Interrupt request flag is cleared by software. Example: When INT4 takes precedence over INTBT SKTCLR IRQ4 : IRQ4 = 1 ? RR **VSUBBT** INT4 interrupt ΕI service routine RETI VSUBBT: CLR<sub>1</sub> IRQBT **INTBT** interrupt service routine EI RETI ## 6.7 Machine Cycles to Interrupt Service Start The number of the $\mu$ PD7500X machine cycles required to start execution of the interrupt routine after an interrupt request flag is set is as shown below: (1) When IRQn is set during execution of an operating instruction at data memory address FBxH (interrupt hardware)) # FBxH address operating instruction As shown above, interrupt routine processing is started a maximum of six machine cycles after the data memory (address FBxH) operating instruction is terminated. (Within a maximum of six machine cycles after the last operating instruction is terminated if the FBxH address operating instructions are successive.) (2) When IRQn is set during execution of instruction other than in (1). In this case, a maximum of six machine cycles are required. # 6.8 Effective Use of Interrupts Use the interrupt function as described below: (1) Set MBE = 0 in the interrupt service routine. If the data memory area used in the interrupt service routine is preferentially allocated to addresses 0-7FH and MBE = 0 is set in the interrupt vector table, a program can be prepared without considering memory banks. If memory bank 1 must be used for by the program, save the memory bank select register by using the PUSH BS instruction and select memory bank 1. (2) Use software interrupt for debugging. When an interrupt request flag is set by an instruction, operating is performed in the same manner as if an interrupt occurred. Debugging when more than one interrupt occurred at the same time can be done effeciently by using an instruction to set an interrupt request flag. ## 6.9 Interrupt Application To use the interrupt function, first set the following in the main program: - (1) Set the interrupt enable flags to be used (EI IEXXX instructions). - (2) To use INTO and INT1, select the active edge. (set IMO and IM1.) - (3) Set the interrupt master enable flag (El instruction). Since MBE is set by using the vector table in an interrupt service program, registers need not be saved or restored, and the interrupt program can be started immediately. To return from the interrupt service program, use the RETI instruction. ### (1) Interrupt enable and disable - ① All interrupts are disabled by the RESET signal. - ② The interrupt enable flags are set by the EI IEXXX instructions. At this stage, all interrupts remain disabled. - 3 The interrupt master enable flag is set by the EI instruction. At this stage, INTO and INTTO are enabled. - The interrupt enable flag is cleared by the DI IEXXX instruction and INTO is disabled. - ⑤ All interrupts are disabled by the DI instruction. (2) Usage example of INTBT, INTO (falling edge active), and INTTO. Multi-interrupt is not done. - $\ \, \textcircled{1}$ All interrupts are disabled by the $\overline{\mbox{RESET}}$ signal and status 0 is set. - ② Falling edge active is selected for INT0. - ③ Interrupts are enabled by the EI and EI IEXXX instructions. - On the INT0 falling edge, the INT0 interrupt service program is started. The status is changed to status 1 and all interrupts are disabled. - A return is made from the interrupt service program by the RETI instruction. The status is restored to status 0 and interrupts are enabled. (3) Pending interrupt execution - interrupt input during interrupt disable - ① If INTO is set during interrupt disable, the request flag is held. When interrupts are enabled by the El instruction, the INTO service program is started. <sup>3</sup> Simular to 1 above. When INTCSI is held enabled, the INTCSI service program is started. ## (4) Pending interrupt execution - If INTO and INTTO are occured at the same time during execution of a single instruction, INTO, which is higher in priority than INTTO, is executed first; INTTO is held. - When a return is made from the INTO service program by the RETI instruction, the held INTTO service program is started. (5) Enable of two double interrupts - INTTO and INTO enable double interrupts; INTCSI and INT4 are single interrupts - ① When interruptINTCSI occurs, which does not enable double interrupts, the INTCSI service program is started. Status 1 is set. ② The status is changed to status 0 by clearing IST0. INTCSI and INT4 do not enable double interrupt and are disabled. When INTTO enables double interrupts, the double interrupt is executed, the status is changed to status 1, and all interrupts are disabled. <sup>4</sup> At the termination of INTTO service, the status is restored to status 0. ⑤ Disabled INTCSI and INT4 are enabled and a return is made by the RETI instruction. #### 7. STANDBY FUNCTION To make the most of low current consumption, which is one feature of the CMOS process, the µPD7500X can stop CPU operation in the standby mode making current consumption by the CPU very small. The uPD7500X standby mode includes the STOP mode and HALT mode. The STOP mode stops the main system clock oscillator. In this mode, CPU current consumption consists almost entirely of leakage current. Data memory can also be held with low supply voltage (up to $V_{DD} = 2$ V). This features is useful for maintaining the data memory contents with very low current consumption. Since the $\mu$ PD7500X STOP mode can be released by using an interrupt request, intermittent operation can also be performed. However, if processing must be started immediately when an interrupt request is made, note that the wait time required to ensure oscillator stability is taken when the STOP mode is released. The HALT mode continues system clock oscillator operation but stops the CPU clock ( $\Phi$ ) supply; thus, CPU operation is stopped. Although the HALT mode is inferior to the STOP mode for reduction of current consumption, it is useful to restart processing immediately according to an interrupt request or for performing intermittent operations such as watch operation. In either mode, all the register, flag, and data memory contents immediately before the standby mode is entered are held. The input/output port output latch state and output buffer state are also held. The input/output port state is handled beforehand so that the current consumption of the entire system is minimized. ## Cautions on Use of Standby Mode: - The STOP mode can be used only when μPD7500X operation uses the main system clock. (Subsystem clock oscillation cannot be stopped.) The HALT mode can be used when the μPD7500X uses either main system or subsystem clock. - 2. Although efficient operation with low current consumption and low voltage can be performed by using the clock change function between the CPU and system clocks in combination with the standby mode, time (described in 5.2.3) is required from selection of a new clock by setting the control register until operation is started by the newly selected clock. Thus, to use the clock change function and the standby mode in combination, set the standby mode within the time required for the clock change. ## 7.1 Standby Mode Setting and Operating State Table 7.1-1 Operating State in Standby Mode | | | STOP mode | HALT mode | | |----------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--| | Setting instruction | | STOP instruction | HALT instruction | | | System clock when standby mode is set. | | Can be set only during main system clock. | Can be set during either main system or subsystem clock. | | | | Clock oscillator | Only the main system clock oscillator is stopped. | Only CPU clock $\Phi$ is stopped (oscillation is continued). | | | | Basic interval timer | Operation stop | Operation (IRQBT is set at reference time intervals.) | | | | Serial interface | Can operate only when external SCK input is selected for serial clock. | Can operate. | | | Operating state | Timer/event counter | Can operate only when TI0 pin input is selected for count clock. | Can operate. | | | | Watch timer | Can operate when $f_{XT}$ is selected for count clock. | Can operate. | | | | External interrupts | INT1, INT2, and INT4 can operate. Only INT0 cannot operate. | | | | | CPU | Operation stop | | | | Release signal | | Interrupt request signal enabl <u>ed with interrupt enable flag from operating</u> hardware (exept for INT0), or RESET input. | | | The STOP mode is set by using the STOP instruction to set PCC bit 3; the HALT mode is set by the using HALT instruction to set PCC bit 2. To change the CPU clock by using the low-order two bits of PCC, a time lag may occur from PCC rewrite to CPU clock change. Thus, to change the clock before the standby mode is entered or after the standby mode is released, set the standby mode within the number of machine cycles required to change the CPU clock after PCC is rewritten. While operation stops during the standby mode, data is held in all registers and data memory such as general-purpose registers, flags, mode register, and output latches. - Caution: 1. When the STOP mode is set, X1 input is short-circuited to $V_{SS}$ (GND potential) internally to suppress crystal oscillator leakage. Therefore, so not use the STOP mode in a system using external clock as a main system slock. - 2. Since an interrupt request signal is used to release the standby mode, if both interrupt request and enable flags are set for an interrupt source, the standby mode is immediately released. Thus, for the STOP mode, the HALT mode is entered immediately after execution of the STOP instruction, a wait is followed according to the setup time of the BTM register, then a return is made to the opertion mode. ## 7.2 Realising Standby Mode The standby mode (STOP or HALT) is released when an interrupt request signal (except INT0) enabled with an interrupt enable flag occurs or RESET is input. Fig. 6.2-1 shows the standby mode release operation. Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (d) Releasing HALT node by interrupt generation Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (cont'd) If the STOP mode is released when an interrupt occurs, the wait time is determined by BTM setting. (See Table 7.2-1.) The time until oscillation becomes stable varies according to the type of oscillator being used and the supply voltage when the STOP mode is released. Therefore, select the wait time according to the conditions of use and set BTM before setting the STOP mode. Table 7.2-1 Wait Time Selection by Using BTM | втмз | ВТМ2 | ВТМ1 | втмо | Wait time* ( ) indicates f <sub>XX</sub> = 4.19 MHz | |------------------|------|------|----------------|------------------------------------------------------------| | - | 0 | 0 | 0 | APPROX. 2 <sup>20</sup> /f <sub>xx</sub> (Approx. 250 ms) | | - | 0 | 1 | 1 | APPROX. 2 <sup>17</sup> /f <sub>xx</sub> (Approx. 31.3 ms) | | - | 1 | 0 | 1 | APPROX. 2 <sup>15</sup> /f <sub>xx</sub> (Approx. 7.82 ms) | | | 1 | 1 | 1 | APPROX. 2 <sup>13</sup> /f <sub>xx</sub> (Approx. 1.95 ms) | | Other than above | | | Use Prohibited | | Note: The wait time when STOP mode is released does not include the time until the clock begins to <u>oscillate</u> after STOP mode is released ((a) in the figure below) regardless of whether STOP mode was released by RESET input or interrupt generation. # 7.3 Operation After Standby Mode is Released - (1) If the standby mode is released when RESET is input, normal reset operation is performed. - (2) If the standby mode is released when an interrupt request occurs, the contents of the interrupt master enable flag (IME) determine whether or not a vectored interrupt is made when the CPU restarts instruction execution. - (a) When IME = 0 - After the standby mode released, execution restarts at the NOP instruction next to the standby mode setting instruction. The interrupt request flags are held. - (b) When IME = 1 - After the standby mode is released, two instructions following the standby mode setting instruction are executed before a vectored interrupt is executed. - However, if the standby mode is released by using INTW or INT2 (testable input), no vectored interrupt will occur; processing as in (a) above is performed. ### 7.4 Application of Standby Mode To use the standby mode, follow the procedure described below: - Detect a standby mode setting source such as interrupt input or port input for power off (it is effective to use INT4 for power off detection). - 2) Handle input/output ports so that current consumption is minimized. - Specify interrupt to release the standby mode. (It is effective to use INT4. Clear the interrupt enables flags so as not to release the standby mode.) - 4) Specify operation after the standby mode is released (set IME depending on whether or not interrupt service is made). - 5) Specify the CPU clock after the standby mode is released. (To change the clock, wait for the required number of machine cycles before setting the standby mode.) - 6) Select the wait time in release of standby mode. - 7) Set the standby mode by using the STOP or HALT instruction. Use of the standby mode and system clock change function in combination enables the $\mu$ PD7500X to operate at low current consumption and low voltage. ## (1) Example of STOP mode application Use the STOP mode under the following conditions - Set the STOP mode when the INT4 falling edge is input and release it when the rising edge is input. (Do not use INTBT.) - Place all input/output ports in high impedance. - Use interrupts INT0 and INTT0 in the example program; however, do not use them to release the STOP mode. - Enable interrupts after the STOP mode is released. - After the STOP mode is released, start operation on the minimum speed CPU clock, and in 250 ms, change it to high-speed clock. - Set the wait time for STOP mode release to about 31.3 ms. - After the STOP mode is released, wait for 31.3 ms for the power supply to become stable. Check the P00/INT4 pin twice and remove chattering. | Programming example - | INT4 service program | with MBF = 0 - | | |-----------------------|----------------------|----------------------------------------------------------------------------------------------------------------|--| | VSUB4: SKT | PORTO.0 | : P00 = 1? | | | BR | PDOWN | ; Power down | | | SET1 | BTM.3 | : Power on | | | WAIT: SKT | IRQBT | ; Waits for 31.3 ms | | | BR | WAIT | tarihin da karantari karantar | | | SKT | PORT0.0 | ; Check chattering | | | BR | PDOWN | | | | MOV | A, #0011B | | | | MOV | PCC, A | ; Set high-speed mode | | | MOV | XA, #XXH | ; Set Port Mode register | | | MOV | PMGm, XA | , | | | El | IE0 | , | | | Ei | IETO | | | | RETI | | | | | PDOWN: MOV | A, #0 | ; Minimum speed mode | | | MOV | PCC, A | , | | | MOV | XA, #00H | | | | MOV | PMGA, XA | ; Place input/output ports in high impedance | | | MOV | PMGB, XA | | | | DI | IE0 | ; Disables INT0 and INTT0 | | | DI | IET0 | | | | MOV | A, #1011B | | | | MOV | BTM, A | ; Wait time = 31.3 ms | | | STOP | | ; Sets STOP mode | | | NOP | | | | | RETI | | • | | | | | | | ## (2) HALT mode application Perform intermittent operation under the following conditions - Change to the subsystem clock on the falling edge of INT4. - Stop oscillation of the main system clock and set the HALT mode. - Perform intermittent operation at 0.5sec. intervals during the standby mode. - Again change to the main system clock on the rising edge of INT4. - Do not use INTBT. ``` Example (Initialization) MOV A, #0011B MOV PCC, A ; High speed mode MOV XA. #04 MOV WM. XA ; Main system clock ΕI IE4 EI IEW ΕI : Enable interrupt (Main routine) SKT PORT0.0 ; Power OK? HALT ; Power down mode NOP : Power OK? SKTCLR IRQW ; Is 0.5sec. flag set? BR MAIN ; NO CALL WATCH : Watch subroutine MAIN: (INT4 service routine) INT4: SKT PORT0.0 ; Power OK?, MBE=0, RBE=0 BR PDOWN CLR<sub>1</sub> SCC.3 ; Start oscillation of main system clock MOV A. #8 MOV BTM, A WAIT1: SKT IRQBT : Wait for 250 ms BR WAIT1 SKT PORT0.0 ; Check chattering BR PDOWN ``` CLR<sub>1</sub> MOV SCC.0 XA. #04H ; Change to main system clock ; Main system clock | MOV | WM, | XΑ | |------|-----|----| | RETI | | | PDOWN: MOV XA, #05H ; Subsystem clock MOV WM, XA SET1 SCC.0 ; Change to subsystem clock MOV A, #6 WAIT2: INCS A INCS A ; Wait for 32 machine cycles BR WAIT2 SET1 SCC.3 ; Stop oscillation of main system clock RETI Note: When the system clock is changed after power on from main system clock to subsystem clock, change the system clock after the subsystem clock is stabilized. ### 8. RESET FUNCTION The $\mu PD7500X$ is reset when $\overline{RESET}$ is input. The hardware devices are initialized as listed in Table 8.1-1. Fig. 8.1-1 shows the reset operation timing. Fig. 8.1-1 Reset Operation by RESET is input Table 8.1-1 State After Each Hardware Device is Reset | | Hard | tware | RESET input during standby mode | RESET input during operation | | |--------------|-------------------------------------------------------------------|-------------------------------|----------------------------------------------------------------------------|------------------------------|--| | Program co | ounter (PC) | μPD75004 | The low-order four bits of program me PC11-PC8. The contents of address 0 | | | | | | μPD75006,<br>μPD75008 | The low-order five bits of program med PC12-PC8. The contents of address 0 | | | | PSW | Carry flag | (CY) | Held | Undefined | | | | Skip flag (SK0-SK2) Interrupt status flag (IST0) Bank enable flag | | 0 | 0 | | | - | | | 0 | 0 | | | | | | Bit 7 of program memory address 0000H is loaded into MBE. | | | | Stack poin | tack pointer (SP) | | Undefined Undefined | | | | Data mem | ata memory (RAM) | | Held (Note) Undefined | | | | General-pu | rpose regis | ters (X, A, H, L, D, E, B, C) | Held | Undefined | | | Bank selec | tion register | (MBS) | 0 | 0 | | | Basic inter | val timer | Counter (BT) | Undefined | Undefined | | | | | Mode register (BTM) | 0 | 0 | | | Timer ever | nt counter | Counter (T0) | 0 | 0 | | | | | Modulo register<br>(TMOD0) | FFH | FFH | | | | | Mode register (TM0) | 0 | 0 | | | | | TOE0, TOUT F/F | 0, 0 | 0, 0 | | | Watch time | er | Mode register (WM) | 0 | 0 | | | Serial inter | face | Shift register (SIO) | Held | Undefined | | Table 8.1-1 State After Each Hardware Device is Reset (Cont'd) | | Hardware | RESET input during standby mode | RESET input during operation | | |--------------------------------|---------------------------------------------------------------------|------------------------------------------------------|------------------------------|--| | Serial | Operation mode register (CSIM) | 0 | 0 | | | interface | SBI control register (SBIC) | 0 | 0 | | | | Slave address register (SVA) | Held | Undefined | | | Clock<br>generator | Processor clock control register (PCC) | 0 | 0 | | | and clock<br>output<br>circuit | System clock control register (SCC) | 0 | 0 | | | | Clock output mode register (CLOM) | 0 | , | | | Interrupt | Interrupt request flags (IRQXXX) | Reset to 0 | Reset to 0 | | | function | Interrupt enable flags (IEXXX) | 0 | 0 | | | | Interrupt master enable flag (IME) | 0 | 0 | | | | INT0, INT1, and INT2 mode registers (IM0, IM1, and IM2) | 0, 0, 0 | 0, 0, 0 | | | Digital | Output buffers | Off | Off | | | ports | Output latches | Cleared | Cleared | | | | Input/output mode registers (PMGA, B) | 0 | 0 | | | | Pull-up resistor specification register (POGA) | 0 | 0 | | | Bit sequent | ial buffer (BSB0-BSB3) | Held | Undefined | | | Pins<br>condition | P00-P03, P10-P13, P20-P23,<br>P30-P33, P60-P63, P70-P73,<br>P80-P81 | Input | Input | | | | P40-P43, P50-P53, | At incorporated pull-up resistor: At open drain: | High level<br>High impedance | | Note: The data of data memory address 0F8H-0FDH is undefined by RESET input. ### 9. ELECTRICAL CHARACTERISTICS ### Absolute Maximum Ratings (Ta = 25 °C) | Item | Symbol | | Conditions | ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) | Ratings | Unit | | |-----------------------|---------------------|----------------------------------------------|------------------------------|-----------------------------------------|------------------------------|------|--| | Supply voltage | V <sub>DD</sub> | | | | -0.3 to +7.0 | V | | | Input voltage | V <sub>I1</sub> | Other than ports | 4 and 5 | | -0.3 to V <sub>DD</sub> +0.3 | V | | | : | V <sub>12</sub> | Ports 4 and 5 With built-in pull-up resistor | | | -0.3 to V <sub>DD</sub> +0.3 | V | | | | | | Open drain | | -0.3 to +11 | V | | | Output voltage | V <sub>o</sub> | | | | -0.3 to V <sub>DD</sub> +0.3 | V | | | High level | I <sub>OH</sub> | Single pin -10 | | -10 | mA | | | | output current | | All pins | | | -30 | IIIA | | | Low level | l <sub>oL</sub> | One port pin of po | ne port pin of ports 0, 3, 4 | | 30 | | | | output current | Note | and 5 | | Effective value | 15 | | | | | | A pin other than p | orts 0, 3, 4 | Peak value | 20 | | | | | | and 5 | | Effective value | 10 | mA | | | Samuel Control | | Total of ports 0, 3 | , 4, 5 | Peak value | 160 | IIIA | | | | - | and 8 | | Effective value | 120 | | | | No. 1 | | Total of ports 2, 6 | and 7 | Peak value | 66 | | | | | Total of ports 2, c | | anu / | Effective value | 33 | | | | Operation Temperature | T <sub>opt</sub> | | | The same | -40 to +85 | °C | | | Storage Temperature | T <sub>stg</sub> | | | | -65 to +150 | °C | | Note: Use the following formula to calculate the effective value. (Effective value) = (Peak value) x $\sqrt{duty}$ # Characteristics of Main System Clock Oscillator (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------------|------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|------|------| | Ceramic<br>resonator | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 1.0 | | 5.0 | MHz | | | C1 C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization time | After V <sub>DD</sub> reaches the minimum value in the oscillator voltage range | | | 4 | ms | | | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 1.0 | 4.19 | 5.0 | MHz | | Crystal<br>resonator | C1 ± ± C2<br>V <sub>DD</sub> | Note 2<br>Oscillation | V <sub>DD</sub> =4.5 to 6.0V | | | 10 | ms | | | | stabilization time | | | | 30 | ms | | External clock | X1 X2 | Note 1<br>X1 input frequency<br>(f <sub>X</sub> ) | | 1.0 | | 5.0 | MHz | | | Д µРD74HCU04 | X1 input high/low level width (t <sub>XH</sub> , t <sub>XL</sub> ) | | 100 | | 500 | ns | Note 1: The oscillation frequency and X1 input frequency are indicated only to express the characteristics of the oscillator. Refer to the AC characteristics for instruction execution time. Note 2: The oscillation stabilization time is the time required for the oscillator to stabillate after V<sub>DD</sub> is applied or after the STOP mode is released. # Subsystem Clock Oscillator Characteristics (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------|-----------------------|-----------------------------------------------------------------------|-----------------------|------|--------|------|------| | Crystal | XT1 XT2 | Oscillation frequency $(f_{XT})$ | | 32 | 32.768 | 35 | MHz | | resonator | | Oscillation stabilization time | $V_{DD} = 4.5 - 6.0V$ | | 1 | 2 | s | | | | Stabilization time | | | | 10 | s | | External clock | Open | XT1 input frequency (f <sub>XT</sub> ) | | 32 | | 100 | kHz | | | | XT1 input high/low level width (t <sub>XTH</sub> , t <sub>XTL</sub> ) | | 5 | | 15 | μs | ## **Recommended Resonator** Main system clock: ceramic resonator | Maunfacture | Product name | | ernal<br>ors (pF) | Oscillator<br>voltage r | Remarks | | |-------------|---------------------------------------------|--------------|-------------------|-------------------------|---------------------------------------|-----------------| | | | C1 | C2 | MIN. | MAX. | | | | CSA 2.00MG093 | 15 | 15 | 2.5 | 3.5 | Note | | | CSB 1000D20 | 220 | 220 | | | | | Murata | CSA 2.00MG093<br>CSA 4.19MGU<br>CSA 4.91MGU | 30 | 30 | 2.7 | 6.0 | | | | CST 2.00MG093<br>CST 4.19MGU<br>CST 4.91MGU | not required | not required | | e e e e e e e e e e e e e e e e e e e | Internal C type | | | KBR-1000H | 100 | 100 | | | | | | KBR-2.0MS | 47 | 47 | | | | | Kyocera | KBR-4.0MS<br>KBR-4.19MS<br>KBR-4.91MS | 33 | 33 | 2.7 | 6.0 | | Note: When CSA 2.000G093 is used, VDD is 2.5 to 3.5V. Main system clock: crystal resonator | Maunfacture | Freg. Holder | Exte<br>capacito | | Oscillator<br>voltage r | Remarks | | |-------------|------------------------------------------------------|------------------|----|-------------------------|---------|--| | | | C1 | C2 | MIN. | MAX. | | | Kinseki | 1.00<br>2.00 HC-18/U<br>4.19 HC-49/U<br>4.91 HC-43/U | 22 | 22 | 2.7 | 6.0 | | ## Subsystem clock: 32.768 KHz crystal resonator | Maunfacture | Product name | ca | External capacitors (pF) | | Oscillator<br>voltage r | Remarks | | |-------------|--------------|---------|--------------------------|--------|-------------------------|---------|--| | | | C1 (pF) | C2 (pF) | R (kΩ) | MIN. | MAX. | | | Kinseki | P-3 | 22 | 22 | 330 | 2.7 | 6.0 | | # Capacitance (Ta = 25 $^{\circ}$ C, $V_{DD} = 0V$ ) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Units | |--------------------------|------------------|---------------------------|------|------|------|-------| | Input capacitance | C <sub>IN</sub> | f =1 MHz | | | 15 | pF | | Output capacitance | C <sub>OUT</sub> | For other than pins to be | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | measured, 0V. | | | 15 | pF | # DC Characteristics (Ta = -40 to +85 $^{\circ}$ C, V $_{DD}$ = 2.7 to 6.0V) | Item | Symbol | | Conditions | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-------------------------------------------|-----------------------------------------------------------------|----------------------|------|--------------------|------| | High level input | V <sub>IH1</sub> | Ports 2, 3 and 8 | | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | voltage | V <sub>IH2</sub> | Ports 0, 1, 6, 7, an | d RESET pin | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | V <sub>IH3</sub> | Ports 4 to 5 | With built-in pullup resistor | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | | | | Open drain | 0.7V <sub>DD</sub> | | 10 | ٧ | | | V <sub>IH4</sub> | X1, X2, XT1 | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | ٧ | | Low level input | V <sub>IL1</sub> | Ports 2, 3, 4, 5, 8 | | 0 | | 0.3V <sub>DD</sub> | V | | voltage | V <sub>IL2</sub> | Ports 0, 1, 6, 7, an | d RESET pin | 0 | | 0.2V <sub>DD</sub> | ٧ | | | V <sub>IL3</sub> | X1, X2, XT1 | | 0 | | 0.4 | ٧ | | High level output voltage | V <sub>OH1</sub> | Ports 0, 2, 3<br>6, 7, 8 | | | | | ٧ | | | | | I <sub>OH</sub> = -100μA | V <sub>DD</sub> -0.5 | | | ٧ | | Built-in pull-up resistor | R <sub>L1</sub> | Ports 0, 1, 2, 3, 6, | V <sub>DD</sub> = 5.0V ± 10% | 15 | 40 | 80 | kΩ | | | | 7, 8 (Except P00)<br>V <sub>IN</sub> = 0V | V <sub>DD</sub> = 3.0V ± 10% | 30 | | 200 | kΩ | | | R <sub>L2</sub> | Ports 4 and 5 | V <sub>DD</sub> = 5.0V ± 10% | 15 | 40 | 70 | kΩ | | | | V <sub>OUT</sub> = V <sub>DD</sub> -2.0V | V <sub>DD</sub> = 3.0V ± 10% | 10 | | 60 | kΩ | | Low level output voltage | V <sub>OL1</sub> | Ports 0, 2, 3, 4, 5, 6, 7, 8 | Ports 4, 5 V <sub>DD</sub> = 4.5-6.0V<br>I <sub>OL</sub> = 15mA | | 0.4 | 2.0 | ٧ | | | | | Port 3 V <sub>DD</sub> = 4.5-6.0V<br>I <sub>OL</sub> = 15mA | | 0.6 | 2.0 | ٧ | | | | | V <sub>DD</sub> = 4.5-6.0V I <sub>OL</sub> = 1.6mA | | | 0.4 | ٧ | | | | | I <sub>OL</sub> = 400μA | | | 0.5 | ٧ | | | V <sub>OL2</sub> | SB0, 1 open drain | Pull-up resistance: $1k\Omega$ min.<br>$V_{DD} = 4.5-6.0V$ | | | 0.2V <sub>DD</sub> | V | | | | | Pull-up resistance: 5kΩ min. | | | 0.2V <sub>DD</sub> | ٧ | | High level input | I <sub>LIH1</sub> | $V_{IN} = V_{DD}$ | Other than indicated below | | | 3 | μΑ | | leakage current | I <sub>LIH2</sub> | | X1, X2, XT1 | | | 20 | μΑ | | ** | I <sub>LIH3</sub> | V <sub>IN</sub> = 10V | Ports 4, 5 (with open drain) | | | 20 | μА | | Low level input | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V | Other than indicated below | | | -3 | μА | | leakage current | l <sub>LIL2</sub> | | X1, X2, XT1 | | | -20 | μΑ | | High level output | I <sub>LOH1</sub> | V <sub>OUT</sub> = V <sub>DD</sub> | Other than indicated below | | | 3 | μА | | leakage current | I <sub>LOH2</sub> | V <sub>OUT</sub> = 10V | Ports 4, 5 (with open drain) | | | 20 | μА | | Low level output leakage current | I <sub>LOL</sub> | V <sub>OUT</sub> = 0V | | | | -3 | μА | ### DC Characteristics (Ta = -40 to +85 °C, $V_{DD} = 2.7$ to 6.0V) | Item | Symbol | | Conditions | | | | | MAX. | Unit | |-------------------------|------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------|-----------|--|------|------|------| | Supply current (Note 1) | | (Note 4) | | | | | 2.5 | 8 | mA | | (Note 1) | DD1 | 4.19 MHz crystal oscillation | V <sub>DD</sub> = 3' | V ± 10% ( | Note 3) | | 0.35 | 1.2 | mA | | | | C1=C2=22pF | HALT | V <sub>DD</sub> = 5 | V ± 10% | | 500 | 1500 | μА | | | DD2 | | Mode | V <sub>DD</sub> = 3 | V ± 10% | | 150 | 450 | μΑ | | | I <sub>DD3</sub> | 32kHz crystal resonator | V <sub>DD</sub> = 3V ± 10% | | | | 30 | 90 | μΑ | | | I <sub>DD4</sub> | (Note 5) | $\begin{array}{ll} \text{HALT} & \text{V}_{\text{DD}} = 3\text{V} \pm 10\% \\ \text{Mode} & \end{array}$ | | | | 5 | 15 | μА | | | | I <sub>DD5</sub> XT1 = 0<br>STOP mode | V <sub>DD</sub> = 5V ± 10% | | | | 0.5 | 20 | μА | | | DD5 | | V <sub>DD</sub> = 3 | V ± 10% | | | 0.1 | 10 | μА | | | | | | | Ta = 25°C | | 0.1 | 5 | μΑ | Note 1: The current of the built-in pull-up resistor is not included. Note 2: When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. Note 3: When operated in the low-speed mode with the PCC set to 0000. Note 4: Includes the power consumption for the sub oscillation. Note 5: When the system clock control register (SCC) is set to 1001, main system clock oscillator is stopped and operated by the subsystem clock. ### AC Characteristics (Ta = -40 to 85 C, $V_{DD}$ = 2.7 to 6.0V) | Item | Symbol | Condi | tion | MIN. | TYP. | MAX | Unit | |---------------------------------------------|-------------------|-------------------------------------|-----------------------|--------|------|-----|------| | (Note 1) Cycle time<br>(minimum instruction | | Operation with main | $V_{DD} = 4.5 - 6.0V$ | 0.95 | , | 64 | μs | | execution time) | ١. | system clock | | 3.8 | | 64 | μs | | | t <sub>CY</sub> | Operation with sub-<br>system clock | | 114 | 122 | 125 | μs | | TIO input from a constant | | $V_{DD} = 4.5 - 6.0 V$ | | 0 | | 1 | MHz | | TI0 input frequency | f <sub>TI</sub> | | | 0 | | 275 | kHz | | TI0 input high/low level width | t <sub>TIH</sub> | $V_{DD} = 4.5 - 6.0V$ | | 0.48 | | | μs | | Width | t <sub>TIL</sub> | | 1.8 | | | μs | | | Interrupt input high/low level width | t <sub>INTH</sub> | INTO | | Note 2 | | | μs | | level width | | INT1, 2, 4 | 10 | | | μs | | | | t <sub>INTL</sub> | KR0-7 | 10 | | | μs | | | RESET low level width | t <sub>RSL</sub> | | | 10 | | | μs | Note 1: The cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure below shows the $V_{DD}$ vs cycle time $(t_{CY})$ when operated with the main system clock. Note 2: 2t<sub>CY</sub> or 128/f<sub>X</sub>, depending on the setting of the interrupt mode register (IM0). ### **Serial Transfer Operation** 2-line/3line serial I/O mode (SCK ... Internal clock output) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------------------------|------------------------|------|------|------| | COV such time | | V <sub>DD</sub> = 4.5 –6.0V | 1600 | | | ns | | SCK cycle time | t <sub>KCY1</sub> | | 3800 | | | ns | | t <sub>KL1</sub> | | V <sub>DD</sub> = 4.5 -6.0V | t <sub>KCY1</sub> -50 | | | ns | | SCK high/low level width | t <sub>KH1</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SI set-up time<br>(against SCK ) | t <sub>SIK1</sub> | | 150 | | | ns | | SI hold time (against SCK ) | t <sub>KSI1</sub> | | 400 | | | ns | | SCK | | V <sub>DD</sub> = 4.5 -6.0V | | | 250 | ns | | SO output delay time | <sup>T</sup> KSO1 | | | | 1000 | ns | ## 2-line/3line serial I/O mode (SCK ... External clock input) | ltem | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-------------------|-----------------------------|------|------|------|------| | 001/ | | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | SCK cycle time | t <sub>KCY2</sub> | | 3200 | | | ns | | t <sub>KL2</sub> | t <sub>KL2</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | | ns | | SCK high/low level width | t <sub>KH2</sub> | | 1600 | | | ns | | SI set-up time (against SCK ) | t <sub>SIK2</sub> | | 100 | | | ns | | SI hold time<br>(against SCK ) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK ↓ — | | V <sub>DD</sub> = 4.5 -6.0V | | | 300 | ns | | SO output delay time | t <sub>KSO2</sub> | | | | 1000 | ns | Note: The output delay time (for rising edge) of the serial line must be shorter than 600 ns. For example, if SB0 and SBI are pulled up with 5K ohms, the total capacitance of the serial bus line must be no greater than 120 pF. SBI mode (SCK ... Internal clock output (master)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------------------------|------------------------|------|------|------| | SCK cycle time | | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | SCK cycle time | t <sub>KCY3</sub> | | 3800 | | | ns | | SCK high/low level | t <sub>KL3</sub> | V <sub>DD</sub> = 4.5 -6.0V | 1 <sub>KCY1</sub> -50 | | | ns | | width | t <sub>KH3</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SB0,1 set-up time (against SCK ) | t <sub>sık3</sub> | | 150 | | | ns | | SB0,1 hold time (against SCK ) | t <sub>KSI3</sub> | | t <sub>KCY1</sub> | | | ns | | SCK - | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 250 | ns | | SB0,1 output delay time | t <sub>KSO3</sub> | | 0 | | 1000 | ns | | SCK - SB0,1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1↓ → SCK↓ | t <sub>sbk</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 high level width | t <sub>sbh</sub> | | t <sub>KCY</sub> | | | ns | # SBI mode (SCK ... External clock input (slave)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |------------------------------------|-------------------|-----------------------------|---------------------|------|------|------| | SCK cycle time | | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | SCK Cycle time | t <sub>KCY4</sub> | | 3200 | | | ns | | SCK high/low level | t <sub>KL4</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | | ns | | width | t <sub>KH4</sub> | | 1600 | | | ns | | SB0,1 set-up time (against SCK † ) | t <sub>SIK4</sub> | | 100 | | | ns | | SB0,1 hold time (against SCK ) | t <sub>KSI4</sub> | | 1 <sub>KCY1</sub> 2 | | | ns | | SCK - | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 300 | ns | | SB0,1 output delay time | t <sub>KSO4</sub> | · | 0 | | 1000 | ns | | SCK - SB0,1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1↓ → SCK↓ | t <sub>SBK</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 low level width | t <sub>sbl.</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 high level<br>width | t <sub>sbh</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1 and XT1 inputs) Clock Timing **TIO Timing** Serial Transfer Timing 3-line serial I/O mode ## **Serial Transfer Timing** Interrupt input timing RESET input timing ### Data Memory STOP Mode Low Voltage Data Retention Characteristic (Ta = -40 to +85 °C) | Item | Symbol | Symbol Condition | | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|------------------------------|-----|---------------------------------|------|------| | Data retention voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention current (Note1) | | V <sub>DDR</sub> = 2.0V | | 0.1 | 10 | μА | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | Ossillation atabilization time (Nets 0) | | Release by RESET input | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | Oscillation stabilization time (Note 2) | twait | Release by interrupt request | | Note 3 | | ms | Note 1: Current in the internal pull-up resistors is not included. Note 2: The oscillation stabilization time is the time required before beginning CPU operation in order to prevent unstable CPU operation when oscillation is initiated. Note 3: Depends on the setting of the basic interval timer mode register (BTM) (refer to the table below). | втмз | BTM2 | BTM1 | ВТМ0 | WAIT time ( ) indicates f <sub>X</sub> =4.19MHz | |------|------|------|------|---------------------------------------------------------| | _ | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>X</sub> (Approximately 250 ms) | | _ | 0 | 1 | 1 | 2 <sup>17</sup> /f <sub>X</sub> (Approximately 31.3 ms) | | | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>X</sub> (Approximately 7.82 ms) | | _ | 1 | 1 | 1 | 2 <sup>13</sup> /f <sub>X</sub> (Approximately 1.95 ms) | Data Retention Timing (when STOP mode is released by RESET input) Data Retention Timing (Standby release signal: STOP mode release by interrupt signal) #### **Characteristic Curves** (Ta = 25 °C) Power supply current IDD (µA) Power supply current IDD (µA) I<sub>DD</sub> vs V<sub>DD</sub> (Ceramic oscillation) (Ta = 25 °C) <sup>\*</sup>The Current values are increased by approximately 10% compared to when operating with a crystal resonator. (Ta = 25 °C) Power supply current I<sub>DD</sub> (µA) Power supply current IDD (µA) I<sub>DD</sub> vs V<sub>DD</sub> (Ceramic oscillation) (Ta = 25 °C) II-1-148 2 3 V<sub>OH</sub> – I<sub>OH</sub> (V) 5 0 1 ## 9.1 Package Information Dimension of 44-pin plastic flat package (units: mm) P44GB-80-3B4 0.8±0.2 42-pin plastic shrink DIP (600 mil) P42C-70-600A Top view Dimension of 44-pin plastic flat package for ES (for reference) (unit: mm) Note 1: A metal cap is connected to pin 17 and is $V_{SS}$ (GND) level. Note 2: Lead wire length is not stipulated because cutting process of lead ends is out of production control. ## 10. μPD75P008 (OTPROM) 4-BIT MICROCOMPUTER The $\mu PD75P008$ replaces the internal ROM of the $\mu PD75004/006/008$ with PROM. The µPD75P008 is available as a one-time PROM version that can be only once written (for small quantity production). µPD75P008 should not be used for final EMI and Latch up evaluation. #### 10.1 Features - μPD75004/006/008 compatible - Internal PROM: 8064 x eigth bits - Internal pull-up resistor (Ports 0-3 and 6-8) can be specified by using software. - Open drain input/output (Ports 4 and 5) - Single power supply: 5V ± 10% ### 10.2 Ordering Information | Produce name | Package | |-----------------|-------------------------------------| | μPD75P008CU | 42-pin plastic shrink DIP | | μPD75P008GB-3B4 | 44-pinplastic flat-pack (bent lead) | #### 10.3 Pin Connection (Top View) #### 10.5 Pin Functions 10.5.1 Port Pins | Pin | Input/Output | Serves as<br>Pin for | Functions | 8-Bit<br>I/O | At Reset | I/O Circuit<br>Type (Note 1) | |---------------------|---------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------------|------------------------------| | P00 | Input | INT4 | 4-bit input port (PORT0). Incorporation of pull-up resistors in 3-bit units for P01 to P03 specifiable by software. | | Input | B | | P01 | Input/Output | SCK | | | | F-A | | P02 | Input/Output | SO/SB0 | | | | F-В | | P03 | Input/Output | SI/SBI | | | | (M) -C | | P10 | Input | INT0 | Noise elimination | Х | Input | <b>B</b> -C | | P11 | | INT1 | function available | | | | | P12 | | INT2 | 4-bit input port (PORT1). Incorporation of pull-up resistors in 4-bit units | | | | | P13 | | TIO | specifiable by software. | | | | | P20 | Input/Output | PTO0 | 4-bit input/output port (PORT2). | X | Input | E-B | | P21 | | | Incorporation of pull-up resistors in 4-bit units specifiable by software. | | 1 1 | | | P22 | | PCL | | | | | | P23 | | BUZ | | | | | | P30 (Note 2) | Input /Output | MD0 | Programmable 4-bit input/output port | | Input | E-B | | P31 (Note 2) | | MD1 | Input/output setting is possible in bit units. In corporation of pull up resistors in 4 bit units | | | | | P32 (Note 2) | | MD2 | specifiable by software. | | | | | P33 (Note 2) | | MD3 | | | | | | P40-P43<br>(Note 2) | Input/Output | | N-channel open drain 4-bit input/output port (PORT4). Data input/output pin (lower 4-bits) for use during program memory (EPROM) write/verify operations. | | High Im-<br>pedance | М-В | | P50-P53<br>(Note 2) | Input/Output | <del>_</del> | N-channel open drain 4-bit input/output port (PORT5). Data input/output pin (upper 4-bits) for use during program memory (EPROM) write/verify operations. | | High Im-<br>pedance | М-В | | P60 | Input/Output | KR0 | Programmable 4-bit input/output port | 0 | Input | F-A | | P61 | | KR1 | (PORT 6). This port can be specified for input/output in | | | | | P62 | | KR2 | bit units. Incorporates software-specifiable pull-up | | | | | P63 | | KR3 | resistors in 4-bit units. | | | | | P70 | Input/Output | KR4 | 4-bit input/output port (PORT7) | | Input | F-A | | P71 | | KR5 | Incorporation of pull-up resistors in 4-bit units specifiable by software. | | | | | P72 | | KR6 | | | | | | P73 | | KR7 | 1 | | | | | P80 | Input/Output | | 2-bit input/output port (PORT8) | Х | Input | E-B | | P81 | 1 | _ | Incorporation of pull-up resistors in 4-bit units specifiable by software. | | | | | | | L | | | | | Note 1: Circles indicate Schmitt trigger inputs. Note 2: LED direct drive is possible. 10.5.2 Non-Port Pins | Pin | Input/Output | Serves as<br>Pin for | Functions | At Reset | I/O Circuit<br>Type (Note 1) | |-----------------|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------| | TIO | Input | P13 | External event pulse input pin for timer/event counter. | - | <b>B</b> -C | | PTO0 | Input/Output | P20 | Timer/event counter output pin. | Input | E-B | | PCL | Input/Output | P22 | Clock output pin. | Input | E-B | | BUZ | Input/Output | P23 | Fixed-frequency output pin (for buzzer or system clock trimming). | Input | E-B | | SCK | Input/Output | P01 | Serial clock input/output pin. | Input | F-A | | SO/SB0 | Input/Output | P02 | Serial data output pin. Serial bus input/output pin. | Input | F-B | | SI/SBI | Input/Output | P03 | Serial data input pin. Serial bus input/output pin. | Input | M-c | | INT4 | Input | P00 | Edge detector vector interrupt input pin (either rising or falling edge detection). | | B | | INTO | Input | P10 | Edge detector interrupt input pin | | В-с | | INT1 | | P11 | (detected edge selectable). | | | | INT2 | Input | P12 | Edge detection testable input pin (rising edge detection). | | B-c | | KR0-KR3 | Input/Output | P60-P63 | Testable input/output pin (for falling edge detection). | Input | F-A | | KR4-KR7 | Input/Output | P70-P73 | Testable input/output pin (for falling edge detection). | Input | F-A | | X1, X2 | Input | | Pin for connection of crystal/ceramics for main system clock generation. External clocks are input to X1, and their negative phase components are input to X2. | | | | XT1 | Input | | Pin for connection of crystals for sub-system clock | | | | XT2 | | | generation. External clocks are input to XT1, and XT2 is disconnected. XT1 can also be used as a 1-bit input (test) pin. | . 1 | | | RESET | Input | | System reset input pin (low level active). | | В | | MD0-MD3 | Input/Output | P30-P33 | Mode selector pin for program memory (EPROM) write/verify operations. | Input | E-B | | V <sub>PP</sub> | | | Program voltage application pin for program memory (PROM) write/verify operations. V <sub>PP</sub> is normally connected to V <sub>DD</sub> . Connect to +12.5V for PROM write/verify operations. | | | | V <sub>DD</sub> | | | Positive power supply pin. | | | | V <sub>ss</sub> | | | GND potential pin. | | | Note 1: Circles indicate Schmitt trigger inputs. Pin I/O configurations Following figures show the internal circuit configurations at the I/O ports. (1) Type A (part of Type E-B) This is a CMOS standard input buffer. (2) Type B This is a Schmitt trigger input with hysteresis characteristics. (3) Type B-C This is a Schmitt trigger input with hysteresis characteristics. (4) Type D (Part of Type E-B, F-A) This is a push-pull output that can be set to high impedance (with both P-ch and N-ch off). (5) Type E-B (6) Type F-A (7) Type F-B II-1-158 ### (10) Type M-B ## (11) Type M-C # 10.6 Differences between $\mu PD75P008$ and $\mu PD75008$ Since the μPD75P008 is the result of changing the program memory of the μPD75004/006/008 from mask ROM to an PROM which can be written, it differs only in program memory and mask option; the two devices are the same in CPU functions and internal hardware. Table 10.6-1 lists the differences between the μPD75P008 and μPD75008. For details on the CPU functions and internal hardware, refer to the µPD004/006/008 documents and user's manual. Table 10.6-1 Differences between $\mu PD75P008$ and $\mu PD75008$ | Item | | μPD75P008 | μPD75008 | | |----------------------|----------------|--------------------------------------------------------------|-------------|--| | Program memory | | PROM | Mask ROM | | | | | • 00000-1F7FH<br>• 8064 bits x eigth bits | | | | Pull-up resistor | Ports 0-3, 6-8 | Can be specified by using so | ftware. | | | - | Ports 4, 5 | None | Mask Option | | | Supply voltage range | | 5V ± 10% 2.7V - 6.0V | | | | Pin connection | | They differ in VPP pin and pins also used for other purpose. | | | #### 10.7 EPROM WRITE AND VERIFICATION Program memory contained in the µPD75P008. The memory capacity is as follows: • μPD75P008: 8064 words x 8 bits The pins as listed in Table 10.7-1 are used to write and verify the PROM. No address is input; address is updated by inputting clock from the X1 pin instead. Table 10.7-1 Pin function | Pin name | Function | | | |-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--| | X1, X2 | Address update clock during when PROM is write/verification is input to the X1 pin. Its inverted signal is input to the X2 pin. | | | | MD0-MD3 | Operation mode selection pins during PROM write/verification. | | | | P40-P43 (low-order four bits)<br>P50-P53 (high-order four bits) | 8-bit data input/output pins during PROM write/verified. | | | | V <sub>DD</sub> | Supply voltage apply pin. During the normal operation, 5 V $\pm$ 10 % is applied; during PROM write/verification, +6 V is applied. | | | | V <sub>PP</sub> | Voltage apply pin during PROM write/ verification. (Normally, V <sub>DD</sub> potential) | | | #### 10.7.1 Operating Mode during PROM is Write/Verification When +6 V and +12.5 V are applied to the V<sub>DD</sub> and V<sub>PP</sub> pins, respectively, of the $\mu$ PD75P008 the PROM write/verify mode is entered. The operation mode is selected according to the input signals to the MD0-MD3 pins as listed in Table 10.7-2. Pins not used in PROM function should be pulled to V<sub>ss</sub>. Table 10.7-2 Operating Mode | | Op | erating mod | le specifica | Operating mode | | | |-----------------|-----------------|-------------|--------------|----------------|-----|------------------------------| | V <sub>DD</sub> | V <sub>PP</sub> | MD0 | MD1 | MD2 | MD3 | Operatingmode | | | | Н | L | Н | L | Clear program memory address | | +12.5 V | +6 V | L | Н | Н | Н | Write mode | | +12.5 V | +6 V | L | L | Н | Н | Verify mode | | | | Н | Х | Н | Н | Program inhibit mode | Remarks: X: L or H #### 10.7.2 PROM Write Procedure PROM can be written at the high speed according to the following Procedure: - Pull unused pins low to V<sub>SS</sub> with resistors. Set the X1 pin low. Supply 5 V to the V<sub>DD</sub> and V<sub>PP</sub> pins. Wait for 10 us. - (4) Selected the clear program memory address mode. - (5) Supply +6 V and +12.5 V to the V<sub>DD</sub> and V<sub>PP</sub> pins. - (6) Select the program inhibit mode. - (7) Write data in the 1-ms write mode. - (8) Select the program inhibit mode. - (9) Select the verify mode. If the data is written normally, proceed to (10). If it is not written normally, repeat (7) to (9). - (10) Supply X (number of (7)–(9) repetitions) x 1 ms program pulses (additional write). - (11) Select the program inhibit mode. - (12) Input four pulses to the X1 pin to update the program memory address by one. - (13) Repeat (7)-(12) until the end address is reached. - (14) Select the clear program memory address mode. - (15) Change the V<sub>DD</sub>, V<sub>PP</sub> pin voltage to 5 V. (16) Turn off the power. Steps (2) to (12) are illustrated below: #### 10.7.3 PROM Read Procdure The PROM contents can be read according to the following procedure: - (1) Pull unused pins low to V<sub>SS</sub> with resistors. - Set the X1 pin low. - Supply 5 V to the $V_{\rm DD}$ and $V_{\rm PP}$ pins. (2) - (3) Wait for 10 µs. - (4) Select the clear program memory address mode. - (5) Supply + 6 V and + 12.5 V to the $V_{\rm DD}$ and $V_{\rm PP}$ pins. - Select the program inhibit mode. (6) - Select the verify mode. Input four clock pulses to the X1 pin. The data are output from the memory addresses, one address at a time, in a cycle of hour clock pulses which are input to the X1 pin. - (8) Select the program inhibit mode. - (9) Select the clear program memory address mode. - (10) Change the V<sub>DD</sub>, V<sub>PP</sub> voltage to 5 V. (11) Turn off the power. Steps (2) to (12) are illustrated below: ## 11. ELECTRICAL CHARACTARISTICS ## Absolute Maximum Rating (Ta≈25°C) | Prameter | Symbol | Condition | | Rating | Unit | |-----------------------------|-------------------------|---------------------------------|------------|------------------------------|------| | Supply voltage | V <sub>DD</sub> | | | -0.3 to +7.0 | ٧ | | | V <sub>PP</sub> | | | -0.3 to +13.5 | V | | Input voltage | V <sub>11</sub> | Other than ports 4 and 5 | | -0.3 to V <sub>DD</sub> +0.3 | V | | | V <sub>12</sub> | Ports 4 and 5 | Open drain | -0.3 to +11 | V | | Output voltage | V <sub>0</sub> | | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | High-level | 1 | Single pin | | -10 | mA | | output current | <sup>I</sup> он | All pins | | -30 | mA | | Low-level<br>output current | Note<br>I <sub>OL</sub> | Ports 0, 3, 4 and 5 | Peak value | 30 | mA | | | | | rms | 15 | mA | | | | Other than ports 0, 3, 4 and 5 | Peak value | 20 | mA | | | | | rms | 10 | mA | | | | Total of ports 0, 3, 4, 5 and 8 | Peak value | 160 | mA | | | | | rms | 120 | mA | | | | Total of ports 2,<br>6 and 7 | Peak value | 66 | mA | | | | | rms | 33 | mA | | Operating temperature | T <sub>opt</sub> | · | | -10 to +70 | °C | | Storage temperature | T <sub>stg</sub> | | | -65 to +150 | °C | Note: Use the following formula to calculate the effective value: (Effective) value = (Peak value) x √ duty cycle # Main system clock Oscillator Characteristics $(Ta = -10 \text{ to } +70^{\circ}\text{C}, V_{DD} = 5V + /-10\%)$ | Resonator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|------|------| | Note 3<br>Ceramic<br>resonator | X1 X2 | Note 1<br>Oscillation<br>frequency (f <sub>XX</sub> ) | | 1.0 | | 5.0 | MHz | | | C1 C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization<br>time | When V <sub>DD</sub> reaches<br>the minimum<br>oscillator operating<br>voltage. | | | 4 | ms | | Crystal resonator | X1 X2 | Note 1<br>Oscillation<br>frequency (f <sub>XX</sub> ) | | 1.0 | 4.19 | 5.0 | MHz | | | C1 — C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization<br>time | | | | 10 | ms | | External clock | X1 X2 | Note 1<br>X1 input<br>frequency (f <sub>X</sub> ) | | 1.0 | | 5.0 | MHz | | | μPD74HCU04 | X1 input high/<br>low level<br>width (t <sub>XH</sub> / t <sub>XL</sub> ) | | 100 | | 500 | ns | - Note 1: The oscillation frequency and X1 input frequency values indicated in this table express only the characteristics of the oscillator. Therefore, refer to the AC characteristics for the instruction execution time. - Oscillation stabilization time is defined as the time needed for the oscillator to stabilize after V<sub>DD</sub> is applied or after the STOP mode is released. - 3: The following ceramic and crystal oscillators are recommended for the μPD75P008. #### **Recommended Ceramic Resonators** | Manufactura | Product | External cap | acitance (pF) | Operating voltage range (V) | | | |-------------|-------------|----------------------------------|----------------------------------|-----------------------------|------|--| | Manufacture | Product | C1 | C2 | MIN. | MAX. | | | MURATA | CSA 2.00MG | 30 | 30 | 4.75 | 5.25 | | | | CSA 4.19MG | 30 | 30 | 4.75 | 5.25 | | | | CSA 4.19MGU | 30 | 30 | 4.75 | 5.25 | | | | CST 4.19MG | 30pF<br>(internally<br>provided) | 30pF<br>(internally<br>provided) | 4.75 | 5.25 | | # Subsystem Clock Oscillator Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V+/-10%) | Resonator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |-------------------|------------------------|-----------------------------------------------------------------------------|-----------|------|--------|------|------| | Crystal resonator | [XT1 XT2]<br>— ξ330 kΩ | Oscillation<br>frequency<br>(f <sub>XT</sub> ) | | 32 | 32.768 | 35 | kHz | | | 22 pF 33 pF | Oscillation<br>stabilization<br>time | | · | 1.0 | 2 | s | | External clock | XT1 XT2 Open | XT1 input<br>frequency<br>(f <sub>XT</sub> ) | | 32 | | 100 | kHz | | | <b>Å</b> | XT1 input high/<br>low level width<br>(t <sub>XTH</sub> /t <sub>XTL</sub> ) | | 5 | | 15 | μs | # Capacitance (Ta =25°C, V<sub>DD</sub> =0V) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------|------------------|------------------------------------------------------------|------|------|------|------| | Input capacitance | C <sub>IN</sub> | f=1 MHz | | | 15 | pF | | Output capacitance | C <sub>OUT</sub> | Voltage should not be applied to any pin except those used | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | for measurements. | | | 15 | pF | # DC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5 $V\pm10\%$ ) | Parameter | Symbol | Con | dition | MIN. | TYP. | MAX. | Unit | |------------------------------|-------------------|-----------------------------------|---------------------------------|----------------------|--------------------|--------------------|------| | | V <sub>IH1</sub> | Port 2, 3 and 8 | | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | High-level | V <sub>IH2</sub> | Port 0, 1, 6, 7, RESET | | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | input voltage | V <sub>IH3</sub> | Port 4, 5 Open-drain | Port 4, 5 Open-drain | | | 10 | V | | | V <sub>IH4</sub> | X1, X2, XT1 | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | ٧ | | | V <sub>IL1</sub> | Port 2, 3, 4, 5 and 8 | | 0 | | 0.3V <sub>DD</sub> | V | | Low-level input voltage | V <sub>IL1</sub> | Port 0, 1, 6, 7, RESET | 0 | | 0.2V <sub>DD</sub> | ٧ | | | , , | V <sub>IL3</sub> | X1, X2, XT1 | X1, X2, XT1 | | 1.0 | 0.4 | ٧ | | High-level<br>output voltage | V <sub>OH1</sub> | Port 0, 2, 3, 6, 7, 8 | I <sub>OH</sub> =-1mA | V <sub>DD</sub> -1.0 | | | V | | High-level | I <sub>LIH1</sub> | V <sub>IN</sub> = V <sub>DD</sub> | Other than indicated below | | | 3 | μА | | input leakage | I <sub>LIH2</sub> | | X1, X2, XT1 | | | 20 | μΑ | | current | I <sub>LIH3</sub> | V <sub>IN</sub> = 10V | Ports 4, 5 (with open drain) | | | 20 | μА | | Low-level | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V | Other than indicated below | | | -3 | μΑ | | current | I <sub>LIL2</sub> | | X1, X2, XT1 | | | -20 | μА | | High level | I <sub>LOH1</sub> | $V_{OUT} = V_{DD}$ | Other than indicated below | - | | 3 | μА | | output leakage<br>current | I <sub>LOH2</sub> | V <sub>OUT</sub> = 10V | Ports 4 and 5 (with open drain) | | | 20 | μΑ | # DC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5 $V\pm10\%$ ) | Parameter | Symbol | Cond | lition | MIN. | TYP. | MAX. | Uni | |------------------------------------|--------------------------------------------|-------------------------------|---------------------------------------------------------|------|------|--------------------|-----| | Low level input<br>leakage current | I <sub>LOL</sub> | V <sub>OUT</sub> = 0V | | | -3 | μА | | | Internal pull-up resistor | R <sub>L1</sub> | Ports 0, 1, 2, 3, 6, 7 (Exc | orts 0, 1, 2, 3, 6, 7 (Except P00) V <sub>IN</sub> = 0V | | | 80 | kΩ | | Low level | V <sub>OL1</sub> | Ports 0, 2, 3, 4, | Ports 4, 5 I <sub>OL</sub> = 15mA | | 0.4 | 2.0 | ٧ | | output<br>leakage | | Port 3 I <sub>OL</sub> = 15mA | 100 | 0.6 | 2.0 | V | | | | | | I <sub>OL</sub> = 1.6 mA | | | 0.4 | ٧ | | | V <sub>OL2</sub> | SB0, 1 Open drain | Open drain Pull-up<br>resistor ≥ 1kΩ | | | 0.2V <sub>DD</sub> | V | | | I <sub>DD1</sub> | Note 3<br>4.19 MHz crystal | Note 2 | | 5 | 15 | mA | | Note 1 | I <sub>DD2</sub> | oscillation C1=C2=22pF | HALT mode | | 500 | 1500 | μΑ | | Supply | | Note 4 | | | 350 | 1000 | | | current | I <sub>DD3</sub> 32kHz crystal oscillation | HALT mode | | 35 | 100 | μА | | | | I <sub>DD4</sub> | XT1 =0V STOP mode | | | 0.5 | 20 | μА | Note 1. The current drained through the internal pull-up resistors is not included. - 2. When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. - 3. Including the subsystem clock power consumption. - When system clock control register (SCC) is set to 1001; main system clock's oscillation stopped once sub-system clock in operation. # AC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V $\pm$ 10%) Operation other than serial transfer operation | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------------------|-------------------------------------|---------------------------------|--------|------|------|------| | Note 1 | | Operated with main system clock | 0.95 | | 64 | μs | | Cycle time (minimum instruction execution time) | t <sub>CY</sub> | Operated with sub-system clock | 114 | 122 | 125 | μs | | TI0 input frequency | f <sub>TI</sub> | A to the | 0 | | 1 | MHz | | TI0 input high/low level width | t <sub>TIH</sub> , t <sub>TIL</sub> | | 0.48 | | | μs | | Interrupt input | | INT0 | Note 2 | | | μs | | high/low level width | INTH' INTL | KR0-7, INT1 2, 4 | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | 10 | | | μs | - Note 1. Cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure to the right shows the $V_{DD}$ supply voltage vs. cycle time $(t_{\rm CY})$ characteristic when operated with the main system clock. - Either 2t<sub>CY</sub> or 64/f<sub>XX</sub> can be selected by setting the interrupt mode register (IM0). ## **Serial Transfer Operation** # 2-line/3-line serial I / 0 mode (SCK....Internal clock output) | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |------------------------------|--------------------------------------|-----------|-----------------------------|------|------|------| | SCK cycle time | t <sub>KCY1</sub> | Output | 1600 | | | ns | | SCK high / low level width | t <sub>KL1</sub><br>t <sub>KH1</sub> | Output | t <sub>KCL1</sub> /2<br>-50 | | | ns | | SI set-up time (against SCK) | t <sub>siK1</sub> | | 150 | | | ns | | SI hold time (against SCK ) | t <sub>KSI1</sub> | | 400 | | | ns | | SCK - S0 output delay time | t <sub>KSO1</sub> | | | | 250 | ns | # 2-line / 3-line serial I/0 mode (SCK....External clock input) : | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------|--------------------------------------|-----------|------|------|------|------| | SCK cycle time | t <sub>KCY2</sub> | Input | 800 | | | ns | | SCK high / low level width | t <sub>KL2</sub><br>t <sub>KH1</sub> | Input | 400 | | | ns | | SI set-up time (against SCK†) | t <sub>SIK2</sub> | | 100 | | | ns | | SI hold time (against SCK † ) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK - S0 output delay time | t <sub>KSO2</sub> | | | | 300 | ns | # SBI Mode (SCK....Internal clock output Master)): | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------|--------------------------------------|-----------|----------------------------|------|------|------| | SCK cycle time | t <sub>KCY3</sub> | | 1600 | | ÷ | ns | | SCK high / low level width | t <sub>кьз</sub><br>t <sub>кнз</sub> | V | t <sub>KCY</sub> /2<br>-50 | | - | ns | | SB0, SB1 set-up time (against SCK1) | t <sub>sıкз</sub> | | 150 | | | ns | | SB0, SB1 hold time (against SCK ) | t <sub>KSI3</sub> | | t <sub>KCY</sub> /2 | | | ns | | SCK → SB0, SB1 output delay time | t <sub>KSO3</sub> | | . 0 | , | 250 | ns | | SCK → SB0, SB1 ↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 SCK | t <sub>SBK</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 high level width | t <sub>sbH</sub> | | t <sub>KCY</sub> | | | ns | # SBI Mode (SCK.... External clock input (Slave)): | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |------------------------------------------------------------|--------------------------------------|-----------|---------------------|------|------|------| | SCK cycle time | t <sub>KCY4</sub> | | 800 | | | ns | | SCK high / low level width | t <sub>KL4</sub><br>t <sub>KH4</sub> | | 400 | | | ns | | $\frac{\text{SB0}}{\text{SCK}}$ , SB1 set-up time (against | t <sub>SIK4</sub> | | 100 | | | ns | | SB0, SB1 hold time (against SCK † ) | t <sub>KSI4</sub> | | t <sub>KCY</sub> /2 | | | ns | | SCK ↓ → SB0, SB1 output delay time | t <sub>KSO4</sub> | | 0 | | 300 | ns | | SCK SB0, SB1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 - SCK | t <sub>sbk</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 high level width | t <sub>SBH</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1, XT1 input) Clock Timing **TIO Timing** Serial Transfer Timing 3-line serial I/O mode # **Serial Transfer Timing** (SBI mode) Bus release signal transfer: # Command signal transfer: Interrupt input timing RESET input timing # Data Memory STOP Mode Low Supply Voltage Data Retention Characteristic ( $Ta = -10 \text{ to } +70 \text{ }^{\circ}\text{C}$ ) | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------------------|-------------------|------------------------------|------|---------------------------------|------|------| | Data retention supply voltage | V <sub>DDDR</sub> | · | 2.0 | | 6.0 | ٧ | | Data retention supply current (Note1) | I <sub>DDDR</sub> | V <sub>DDDR</sub> = 2.0V | | 0.1 | 10 | μΑ | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | | | Release by RESET input | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | Oscillation stabilization wait time (Note 2) | twait | Release by interrupt request | | Note 3 | | ms | Note 1: The current drained through the internal pull-up resistor is not included Note 2: The oscillation stabilization wait time is used to prevent unstable CPU operation at the beginning of oscillator operation, during which CPU operation is disabled. Note 3: This value depends on the setting of the basic interval timer mode register (BTM). (Refer to the table below.) | втмз | BTM2 | BTM1 | ВТМ0 | WAIT time Parantheses ( ) indicates $f_{\chi} = 4.19 MHz$ | |------|------|------|------|-----------------------------------------------------------| | _ | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>X</sub> (Approximately 250 ms) | | | 0 | 1 | 1 | 2 <sup>17</sup> /f <sub>X</sub> (Approximately 31.3 ms) | | _ | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>X</sub> (Approximately 7.82 ms) | | _ | 1 | 1 | 1 | 2 <sup>13</sup> /f <sub>X</sub> (Approximately 1.95 ms) | Data Retention Timing (Releasing STOP mode by RESET) Data Retention Timing (Standby release signal: Releasing STOP mode by interrupt signal) # DC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) | Item | Symbol | Test Conditions | MIN. | TYP. | MAX. | Unit | |------------------------------------------|------------------|------------------------------------------------------|----------------------|------|---------------------|------| | High level input voltage | V <sub>IH1</sub> | Other than X1, X2 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | es e | V <sub>IH2</sub> | X1, X2 | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | ٧ | | Low level input voltage | V <sub>IL1</sub> | Other than X1, X2 | 0 | | 0.3 V <sub>DD</sub> | ٧ | | | V <sub>IL2</sub> | X1, X2 | 0 | | 0.4 | V | | Input leak current | I <sub>LI</sub> | V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | | | 10 | μΑ | | High level output voltage | V <sub>oh</sub> | I <sub>OH</sub> = -1 mA | V <sub>DD</sub> -1.0 | | | ٧ | | Low level output voltage | V <sub>OL</sub> | l <sub>OL</sub> = 1.6 mA | | | 0.4 | ٧ | | V <sub>DD</sub> power supply current | I <sub>DD</sub> | | | | 30 | mA | | V <sub>PP</sub> power supply current | I <sub>PP</sub> | MD0 = V <sub>IL</sub> , MD1 = V <sub>IH</sub> | | | 30 | mA | Note 1: Ensure that $V_{pp}$ does not exceed +13.5V including overshoot. Note 2: Ensure that $V_{DD}$ is applied before $V_{pp}$ , and is turned off after $V_{pp}$ . # AC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) | Item | Symbol | Note 1 | Test Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|----------------------------------|--------------------|--------------------------------------------|-------|------|------|------| | Address setup time (Note 2) (to MD0 ) | t <sub>AS</sub> | an t <sub>AS</sub> | | 2 | | | μs | | MD1 setup time (to MD0 ) | t <sub>M1S</sub> | t <sub>OES</sub> | | 2 | | | μs | | Data setup time (to MD0 ↓ ) | t <sub>DS</sub> | t <sub>DS</sub> | | 2 | | | μs | | Address hold time (Note 2) (to MD0 ) | t <sub>AH</sub> | t <sub>AH</sub> | | 2 | | | μs | | Data hold time (to MD0 ) | t <sub>DH</sub> | t <sub>DH</sub> | | 2 | | | μs | | MD0 data output float delay time | t <sub>DF</sub> | t <sub>DF</sub> | | 0 | | 130 | ns | | V <sub>PP</sub> setup time (to MD3 † ) | t <sub>vps</sub> | t <sub>vps</sub> | | 2 | | | μs | | V <sub>DD</sub> setup time (to MD3 † ) | t <sub>VDS</sub> | t <sub>vcs</sub> | Ç. Est | 2 | | | μs | | Initial program pulse width | t <sub>PW</sub> | t <sub>PW</sub> | | 0.95 | 1.0 | 1.05 | ms | | Additional program pulse width | t <sub>OPW</sub> | t <sub>OPW</sub> | | 0.95 | | 21.0 | ms | | MD0 setup time (to MD1 ) | t <sub>mos</sub> | t <sub>CES</sub> | | 2 | | | μs | | MD0 data output delay time | t <sub>DV</sub> | t <sub>DV</sub> | MD0 = MD1 = V <sub>IL</sub> | | | .1 | μs | | MD1 hold time (to MD0 ) | t <sub>M1H</sub> | t <sub>OEH</sub> | t <sub>M1H</sub> = t <sub>M1R</sub> ≥ 50μs | 2 | | | μs | | MD1 recovery time (to MD0 ) | t <sub>M1R</sub> | t <sub>OR</sub> | | 2 | | | μs | | Program Counter reset time | t <sub>PCR</sub> | | · | 10 | | | μs | | X1 input high/low level width | t <sub>xH</sub> ,t <sub>xL</sub> | _ | | 0.125 | | | μs | | X1 input frequency | f <sub>x</sub> | | | | | 4.19 | MHz | | Initial mode setting time | t, | | | 2 | | | μs | | MD3 setup time (to MD1 ) | t <sub>mas</sub> | | | 2 | | | μs | # AC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) (cont'd) | Item | Symbol | Note 1 | Test Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|------------------|----------------------------|------|------|------|------| | MD3 hold time (to MD1 ) | t <sub>мзн</sub> | _ | | 2 | | | μs | | MD3 setup time (to MD0 ) | t <sub>M3SR</sub> | _ | For program<br>memory read | 2 | | | μs | | Address (Note 2) data output delay time | t <sub>DAD</sub> | t <sub>ACC</sub> | For program<br>memory read | 2 | | | μs | | Address (Note 2) data output hold time | t <sub>HAD</sub> | t <sub>oн</sub> | For program<br>memory read | 0 | | 130 | ns | | MD3 hold time (to MD0 † ) | t <sub>мзня</sub> | | For program<br>memory read | 2 | | | μs | | MD3 data output float delay time | t <sub>DFR</sub> | _ | For program<br>memory read | 2 | | | μs | Note 1: Symbol for corresponding $\mu PD27C256$ . Note 2: The internal address signal is incremented by 1 by the rise of the 4th X1 input, and is not connected to a pin. # Program Memory Write Timing # Program Memory Read Timing # 11.1 Package Information Dimension of 44-pin plastic flat package (units: mm) Top view P44GB-80-B4 42-pin plastic shrink DIP (600 mil) Top view # CHAPTER 2 µPD75268 STANDARD MICROCOMPUTER WITH FIP CONTROLLER/DRIVER # 1. OVERVIEW The $\mu PD75268$ is a 4-bit single-chip microprocessor with a fluorescent indicator lamp (FIP) controller/driver built in. The product has a 512 x 4 bit RAM, and a FIP controller/driver for controlling 9 to 16 segments. The standard μCOM-75X instruction set, which is compatible with μPD75008 software, is used. The $\mu$ PD75268 is a high-speed microcomputer with an FIP display function, and consumes less power. The $\mu$ PD75268, as a VTR timer/tuner microcomputer, is suitable for low-end to high-end VTRs. In addition, the microcomputer can find a wide range of applications: ## 1.1 Features - · Audio equipment (such as CD players) - · Electronic cash register (ECR) - · Telephon set - Electronic balance - Automobile # 1.2 Ordering Information | Nomenclature | Package | |--------------------|--------------------------------------------------| | μPD75268CW-xxx | 64-pin plastic shrinked-<br>dual-in-line-package | | μPD75268GF-xxx-3BE | 64-pin plastic quad- flat package | Remarks: xxx represents a ROM code number. # 1.3 List of Functions | Item | Function | | | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Internal memory Capacity | ROM: 8064 x 8 bits, Ram: 512 x 4 bits (μPD75268) | | | | I/O line | 54 lines • Input : 8 lines • I/O: 20 lines (LED drive: 8 lines) • High-voltage output: 26 lines (40 V <sub>max</sub> ) | | | | Instruction cycle | • 0.95 μs, 1.91 μs, 15.3 μs/4.19 MHz<br>• 122 μs/32.768 kHz | | | | FIP controller/driver | Number of segments: 9 to 16 segments Number of digits: 9 to 16 digits Dimmer function: 8 stages Pull-down resistor mask option Key scan interrupt generation | | | | Timer | 3 channels - Watch timer: With buzzer function - Timer/event counter - Basic interval timer: Usable as a watchdog timer | | | | Serial interface | Allows MSB/LSB inversion for starting transfer. Allows a serial bus configuration. | | | | Interupt | Allows multiple hardware interrupts. External interrupts: External test input: Internal interrupts Internal test input: I | | | | System clock generator | Two build-in circuits - When main system clock is used: 4.194304 MHz standard - When subsystem clock is used: 32.768 kHz | | | | Mask option | High-voltage port (pull-down resistor) Port 6 (pull-down resistor) | | | | Operation temperature | -40 to +85°C | | | | Operating power supply voltage | 2.7 to 6.0 V (standby data preservation: 2.0 to 6.0 V) | | | | Package | 64-pin plastic shrinked-dual-in-line package 64-pin plastic quad-flat package | | | # 1.4 Functions of the Products in the Family | Name | | μPD75206 | μPD75208 | μPD75268 | μPD75212A | μPD75216A | μPD75P216A | |----------------------------------------|----------------------------------------------------|------------------------------|-----------------|-------------------------------|---------------------|------------------|------------------------------------------------| | Internal<br>memory | ROM | 6016 x 8 | 806 | 4 x 8 | 12160 x 8 | 16256 x 8 | 16256 x 8<br>(One-time<br>PROM) | | | RAM | 369 x 4 | 497 x 4 | | 512 x 4 | | | | General-<br>purpose<br>regisger | | 4 bits x 8<br>x 4 banks | | | | 4 bits x 8 x | 4 banks | | | Input only | 8 lines: Input | ports (used as | serial inputs, tim | er input, and int | errupts as well) | | | | | 20 lines: 8 LE | D drive lines | | | | | | | 1/0 | Port6: With a | pull-down resis | tor (mask optior | )) | | Port 6: With-<br>out pull-down<br>resistor | | I/0 line | Output only | 1 line: PPO | | None | 1 line: PPO | | ÷ | | | | 26 lines: 40 \ | MAX. | | | | | | | Hight-voltage | Incorporation bit (mask opti | | resistor or open | drain output is s | elected bit by | S0-S8, T0-T9:<br>With a pull-<br>down resistor | | | 55,65 | on (maon op. | | | | | S9, T10- T15:<br>Open drain<br>output | | FIP con- | Number of<br>segments | 9 to 12 segments | | | 9 to 16 segm | ents | | | troller/driver | Number of digits | 9 to 16 digits | | | | | | | Timer /pulse<br>14-bit PWM o<br>bility | gemeratpr (with<br>output capa- | Available | | Not available | | Available | | | Serial interfac | ce | | J/LSB inversion | for starting trans<br>ration. | sfer. | | | | Interrupt sour | rces | Extnl: 4<br>Intnl: 6 | | Extnl: 4<br>Intnl: 5 | Extnl:4<br>Intnl: 6 | | | | Interrupt prior | rity specification | Available | | Not Available | Available | | | | Instruction | Class | High-end | | Standard | High-end | | | | set | 1-bit transfer | | | | | | | | | 8-bit transfer | | | | | | | | | @HL+,<br>@HL-, Indi-<br>rect branch<br>instruction | Available | | Not available | | Available | | | Power-on res | et circuit | Mask option | | Not available | Mask option | | Not available | | Power supply | / voltage | | | 2.7 to 6.0 V | | 5 V ± | | 11-2-4 1.5 Block Diagram ## 1.6 Pin Configuration 64 Pin Flat Pack μPD75268 | P00–P03<br>P10–P13<br>P20–P23<br>P30–P33<br>P40–P43<br>P50–P53<br>P60–P63<br>PH0-PH3<br>T0-T15<br>S0-S11/S15 | : Port0 : Port1 : Port2 : Port3 : Port4 : Port5 : Port6 : PortH : Digits : Segments | V <sub>SS</sub><br>SI<br>SCK<br>V <sub>DD</sub><br>SO<br>INT0, INT1<br>INT2<br>INT4<br>TI0<br>X1, X2<br>XT1, XT2<br>RESET | : GND : Serial Data input : Serial Clock Input/Output : Positive Power Supply : Serial Data Output : Interrupt Inputs : Interrupt Input : Interrupt Input : Input External Event Pulse : Main System Clock Crystal : Subsystem Clock Crystal : Reset | |--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | • | | | | IC<br>BUZ | : (*)<br>: 2kHz Buzzer Output | V <sub>PRE</sub><br>V <sub>LOAD</sub> | <ul><li>: Power Supply for High-Voltage Output Predriver</li><li>: Power Supply for High-Voltage Output Driver</li></ul> | | | | 205 | | (\*) Internal connected # 64 Pin Shrink DIP μPD75268CW #### 2. PIN FUNCTIONS 2.1.1 P00–P03 (Port 0) . . . Inputs shared by INT4, SCK, SI, and SO P10–P13 (Port 1) . . . Inputs shared by INT0, 1, 2, and TI0 These are 4-bit input ports for Ports 0 and 1. Port 0, in addition to input port function, also provides vector interrupt input (INT4) and serial interface input/output (SCK, SI, SO) functions. Port 1 also functions as vector interrupt input (INT0, INT1) and edge–detection test input (INT2). P10 and P11 have a noise eliminator. The data on the Port 0 and Port 1 lines can always be input regardless of the currently selected pin functions. The P00 (INT4), P01 (SCK), and P03 (SI) inputs of Port 0 and all inputs of Port 1 have Schmitt trigger inputs. 2.1.2 P20–P23 (Port 2), P30–P33 (Port 3), P40–P43 (Port 4), P50–P53 (Port 5), P60–P63 (Port 6) . . . 3–State I/Os These are 3-state, 4-bit CMOS input/output ports with output latches (for Ports 2 through 6). Ports 4 and 5 provide large-current output for direct LED drivability. An internal reset signal (RES) clears the output latches on all ports to zeros and places all pins in the Input mode (all outputs set to high impedance). The Port Mode register is used to select either Input or Output mode. For Ports 3 and 6, Input/Output mode can be selectes for each bit. For Ports 2, 4, 5, mode selection is always in 4-bit units. Ports 4 and 5, may be paired to allow input/output in 8-bit units. Port 2, in addition to I/O port function, also functions as output (BUZ). Port 6 has low V<sub>II</sub> and can have on chip pull-down resistors as mask option, therefore it is best suited as a key input port. 2.1.3 PH0-PH3 (PORT H) . . . P-ch open drain high-voltage output pins also used for T10/S15-T13/S12 PH0-PH3 are P-ch open drain 4-bit high-voltage, high-current output port pins with output latch. High current output for direct LED drive. Internal pull-down resistor can also be included on the pins by mask option. When the internal reset signal (RES) is generated, the pins are placed in high impedance, but they will go low if the internal pull-down resistor is included. In addition to the P-ch open drain output function, port H can also be used for high-voltage digit/segment output (T13/S15-T10/S12). 2.1.4 T0-T9 . . . P-ch open drain high-voltage output T0-T9 are high-voltage, high-current output pins for FIP controller/driver timing (digit) signals. An internal pull-down resistor can be included for each pin using mask option. When the internal reset signal (RES) is generated, the pins are placed in high impedance, but they will go low if the internal pull-down resistor is included. 2.1.5 T10/S15-T13/S12 . . . P-ch open drain high-voltage output pins also used for port H T10/S15-T13/S12 are high-voltage, high-current output pins used for both FIP controller/driver digit and segment outputs. The digit signal or segment signal can be selected for each pin. The timing signals are preferential, however, and the timing mode register is used for control. An internal pull-down resistor van be included for each pin by mask option. When the internal reset signal (RES) is generated, the pins are placed in high impedance, but they will go low if the internal pull-down resistor is included. The T10/S15-T13/S12 pins, when not used for digit/segment signal high voltage output, can also be used for digit/segment signal high-voltage output (PORT H). #### 2.1.6 T14/S11 and T15/S10 . . . P-ch open drain high-voltage output T14/S11 and T15/S10 are high-voltage, high-current output pins for FIP controller/driver digit and segment outputs. The digit signal or segment signal can be selected for each pin. The timing signals are preferential, however, and the timing mode register is used for control. When not used for display, the pins can be used as a static output port. An internal pull-down resistor can be used for each pin by mask option. When the internal reset signal (RES) is generated, the pins are placed in high impedance, but they will go low if the internal pull-down resistor is included. ## 2.1.7 S0-S9 . . . P-channel, open-drain, high-voltage outputs These pins serve as high-voltage outputs to provide segment signals for the FIP controller/driver. Pin S9 can be used as a static output port when not used for display purposes. Each of these pins can be provided with a pull-down resistor as mask option. An internal reset signal (RES) sets each pin to high impedance if provided with no pull-down resistor, or to low level if provided with a pull-down resistor. # 2.1.8 TI0 . . . Input, shared with P13 These input accept external event pulses for internal timer/event counter: It may also be used as edge-detection vector interrupt input by setting the timer/event counter mode registers (TM0). Since it is mapped on the data memory space, the pin status can be read or tested. Both inputs have Schmitt trigger circuits. #### 2.1.9 BUZ . . . Output (multiplexed with Port 2) This pin provides a fixed-frequency output (2.048kHz) usable for buzzer driving or trimming of the system clock frequency. It shares the pin function with pin P23, and is valid only if bit 7 (WM7) of the Clock Mode register (WM) is set to one. An internal reset signal (RES) resets WM7 to zero, which causes this pin to subsequently function as a general I/O port. # 2.1.10 SCK, SO, SI . . . 3-State I/O shared by Port 0 These are 3-state serial interface input/output pins. They become effective by settings on the Serial Operation Mode register. An internal reset signal (RES) stops serial interface operation and restores the normal input port function for Port 0. The SCK and SI pins have Schmitt trigger inputs. # 2.1.11 INT0, INT1 . . . Interrupt inputs shared by Port 1 These are external vector interrupt inputs at Port 1. Operation modes for these inputs can be specified with the Edge Detection Mode register from the following (see 5.3): - Rising-edge active - ② Falling-edge active - 3 Both-edge active - External interrupt input disable Both INT0 and INT1 are synchronous inputs with noise suppress circuits. The acceptable pulse differs depending on the CPU clock rate. This inputs are unable to clear the standby mode. An internal reset signal (RES) selects rising-edge active mode. Both INT0 and INT1 pins have Schmitt trigger inputs. ## 2.1.12 INT2 . . . Test input shared by port 1 This is a rising—edge active, external test input at Port 1. An internal test flag is set when the signal applied to this input is set from Low to High. INT2 is an asynchronous input, which accept signals with a certain width of High level regardless of the CPU clock timing. INT2 may also be used to clear the STOP or HALT mode. It has a Schmitt trigger input. #### 2.1.13 INT4 . . . Interrupt Input shared by Port 0 This is a both—edge (rising—and falling—edge active, external vector interrupt input). An internal Interrupt Request flag is set when the signal applied to this input is set from Low to High or vice versa. INT4 is an asynchronous input, which accepts a signal with a certain High or Low level with no regard to the CPU clock timing. INT4 may also be used to clear the STOP or HALT mode. It has a Schmitt trigger input. #### 2.1.14 X1 and X2 X1 and X2 are connection pins for the main system clock crystal / ceramic oscillator. External clocks can also be input. (a) Crystal ceramic oscillator (b) External clock #### 2.1.15 XT1 and XT2 XT1 and XT2 are crystal connection pins for the subsystem clock oscillation. External clocks can also be input. (b) External clock # 2.1.16 RESET This is an active Low reset input. It is an asynchronous input, which accepts a signal with a certain Low level width with no regard to the system clock timing. A signal input to this pin causes an internal reset signal (RES) to be generated, which provides a system reset overriding all other operations. In addition to CPU initialization and start, this input has a Schmitt trigger input. This pin supplies power to the predriver for the FIP controller/driver. This pin supplies power to pull-down resistors which are provided (as a mask option) at the segment and timing output pins for the FIP controller/driver. This pin accepts a positive supply voltage for the device. V<sub>SS</sub> is the ground pin. 2.1.21 IC This pin is internally connected. It must be open. Table 2.1-1 List of Digital I/O Pin Functions | Name | Input/output | Shared with | Function | 8-bit I/O | When reset | Circuit type | |---------------|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------|--------------| | P00 | Input | INT4 | 4-bit input port (Port 0) | х | Input | ® •₁ | | P01 | Input/output | SCK | <del></del> | | | Ē •₁ | | P02 | Input/output | so | | | | © +₁ | | P03 | Input | SI | | | · | ® ∗1 | | P10 | Input | INTO *2 | 4-bit input port (Port 1) | | Input | ® | | P11 | | INT1 +2 | | | | | | P12 | | INT2 | | | | | | P13 | | TIO | | | | *1 | | P20 | Input/output | _ | 4-bit input/output port (Port 2) | X | Input | E | | P21 | | _ | | | | | | P22 | | _ | | | | | | P23 | | BUZ | | | | | | P30 to<br>P33 | Input/output | <u></u> | 4-bit programmable input/output port (Port 3). Input or output can be specified per bit. | | Input | E | | P40 to<br>P43 | Input/output | _ | 4-bit input/output port (Port 4). Can directly drive LEDs. | 0 | Input | E | | P50 to<br>P53 | Input/output | _ | 4-bit input/output port (Port 5). Can directly drive LEDs. | | Input | E | | P60 to<br>P63 | Input/output | _ | 4-bit programmable input/output port (Port 6). Input or output can be specified per bit. Internal pull-down resistors provided (mask option). Suited for key input. | × | Input | V | | PH0 | Output | T13/S12 | 4-bit P-ch open drain high-voltage, high- | Х | | ı | | PH1 | | T12/S13 | current output port (Port H). Can directly drive LEDs. Internal pull-down resistors can | | | | | PH2 | . * | T11/S14 | be built in (mask operation). | · | - | | | PH3 | | T10/S15 | | | | | <sup>\*1:</sup> Indicates Schmitt trigger input. <sup>\*2:</sup> With noise eliminator circuit. Table 2.1-2 List of Other Pin Functions | Name | Input/output | Shared with | Fun | ction | When reset | Circuit type | |--------------------|--------------|-------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------| | T0 to T9 | Output | | FIP controller/driver output pins. Pull-down | High-voltage, high-current output pins for digit output. | Low level<br>(when pull- | 1 | | T10/S15<br>T13/S12 | | PH3-PH0 | resistor can be built-in per<br>bit (mask option) | High-voltage high-current<br>output pins usable for digit/<br>segment output as well.<br>Any unused pins can be<br>used for PORT H. | down resi-<br>stors are<br>built-in) or<br>high impe-<br>dance<br>(when no | | | T14/S11<br>T15/S10 | | | | High-voltage, high-current output pins for segment output. Static output also possible. | pull-down<br>resistors<br>built in) | | | S9 | | | * | High-voltage output pin for segment ouput. Static output also possible. | | | | S0 to S8 | | : | | High-voltage output to pins for segment output. | | | | IC | _ | - | Internally connected. It mus | st be open. | | _ | | TIO | Input | P13 | Inputs external event pulse | to the timer/event counter. | | ® | | SCK | Input/output | P01 | Serial data input/ouptut pin | | Input | Ē | | so | Input/output | P02 | Serial data output pin or se | rial data input/output pin. | | G | | SI | Input | P03 | Serial data input pin or nor | mal input pin. | | B | | INT4 | Input | P00 | Edge detect vectored interr<br>falling edges can be detect | rupt input pin (both rising and ed). | | B | | INT0 | Input | P10 | Edge detect vectored interr | | | B | | INT1 | | P11 | elimination circuit (either ris detected). | sing or failing edge can be | | | | INT2 | Input | P12 | Edge detected testable inp | ut pin (rising edge detected). | | B | | BUZ | Input/output | P23 | Fixed frequency output pin trimming). | (for buzzer or system clock | Input | E | | X1, X2 | | | Crystal or ceramic resonate is connected across these is used, use X1 to input the phase to X2. | | | | | XT1,<br>XT2 | | _ | Crystal for subsystem clock<br>pins. When the external clo<br>the external clock and leave | : | | | | RESET | Input | _ | System reset input pin (low-level active). | | | B | | V <sub>PRE</sub> | | | FIP controller/driver output | | 1 | | | V <sub>LOAD</sub> | | | FIP controller/driver pull-do | | 1 | | | V <sub>DD</sub> | - | | Positive power supply pin. | | - | | | V <sub>ss</sub> | | | GND | | | | <sup>\*</sup> Circuits enclosed by circle have Schmitt trigger input. Fig. 2.1-1 Pin I/O Circuit # 2.2 Recommended Conditions for Unused Pins | Pin | Recommended conditions | |--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | P00 | Connect to V <sub>SS</sub> . | | P01-P03 | Connect to V <sub>SS</sub> or V <sub>DD</sub> . | | P10-P13 | Connect to V <sub>SS</sub> . | | P20-P23<br>P30-P33<br>P40-P43<br>P50-P53<br>P60-P63 | Input mode: Connect to $\rm V_{SS}$ or $\rm V_{DD}$ . Output mode: No connection is required. | | IC<br>S0-S9<br>T15/S10-T14/S11<br>T0-T9<br>T10/S15/PH3-T13/S12/PH0 | No connection required. | | XT1 | Connect to V <sub>SS</sub> or V <sub>DD</sub> . | | XT2 | No connection required. | | RESET with internal power-on circuit | Connect to V <sub>DD</sub> . | | V <sub>LOAD</sub> without on-chip load resistor | Connect to V <sub>SS</sub> or V <sub>DD</sub> . | # 2.3 Cautions on Use of P00/INT4 and RESET Pins The P00/INT4 and RESET pins have the test mode setting function (IC test) to test internal operation of μPD75268 in addition to the functions described in 2.1.11 and 2.1.13. When voltage exceeding $V_{DD}$ is applied to either of the pins, the test mode is set. Thus, if noise exceeding $V_{DD}$ is applied during normal operation, the test mode is entered and the normal operation may not be continued. For example, if wiring from the P00/INT4 or RESET pin is long, inter-wiring noise is applied to the pin, the pin voltage exceeds V<sub>DD</sub>, and malfunction may be caused. Thus, wire so as to suppress inter-wiring noise as much as possible. If noise cannot be suppressed, use an external part as shown below: • Insert capacitor between the P00/INT4 or RESET pin and VDD #### 2.4 Note for use of XT1, XT2 and P50 pins When 32.768kHz subsystem clock is used for source clock of watch timer, switching frequency of input and/or output signals on P50 pin which is placed next to the XT2 pin should be lower than once in a second. If signals of P50 pin has higher frequency, spike noises are generated on XT2 pin by capacitive coupling of P50 and XT2 pins. As a result, normal watch function will not be given (Watch will run too fast). In this case, external capacitor will be needed on P50 pin like in the following figure. # 3. μPD75268 ARCHITECTURE AND MEMORY MAP The following three points are features of the $\mu$ COM75X's that are adopted to the $\mu$ PD75268 architecture. - (1) Data memory in bank configuration - (2) Memory-mapped I/O This chapter discribes each of these features. # 3.1 Data Memory in Bank Configuration and Addressing Mode ### 3.1.1 Data memory in bank configuration The $\mu$ PD75268 contain a general-purpose RAM space up to 512 x 4 words of of the data memory, and peripheral hardware (I/O ports, timer, etc.) on addresses F80H to FFFH of the data memory. The 64 x 4 bits at address 1C0H to1FFH are also used as display data memory. To address the 12-bit data address space the $\mu$ PD75268 employ memory bank configuration in which the lower 8-bit addresses are specified by instructions either directly or indirectly and the higher 4-bit addresses are specified by memory bank (MB). To specify a memory bank (MB), the $\mu$ PD75268 contain: - · Memory bank enable flag (MBE) - Memory bank select register (MBS) The MBS register is used to select a specific memory bank. On the µPD75268, values 0, 1, or 15 can be preset into this register. The MBE flag specifies whether the bank selected by the MBS register is to be made valid or not. If the MBE flag is reset (zero), a fixed memory bank is selected with no regard to the MBS (see Fig. 2.1-1). If the MBE is set (1), memory bank can be changed by the MBS setting to expand the data memory space. For addressing data memory space, the MBE flag is usually set (1) and the data memory area in the memory bank specified by the MBS is manipulated. Efficient programming is possible by using the MBE=0 and MBE=1 modes adequately. | | Possible program processes | Effect | |------------|-------------------------------------------------------------------------------------------------|-----------------------------------------| | | •Interrupt process | Save/restore for MBS data is not needed | | MBE=0 mode | Process in which internal hardware manipulation<br>and general-purpose RAM access are repeated. | Updating to MBS data is not needed | | | Subroutine process | Save/restore for MBS data is not needed | | MBE=1 mode | Normal program process | | Since the MBE is automatically saved/restored in a subroutine procedure, it can be freely changed during subroutine process. In an interrupt procedure, the MBE in the interrupt service can be specified automatically at the beginning of interrupt service routine by presetting of interrupt vector table, while the MBE is stored/restored automatically. This realizes fast interrupt operation. If the MBS is to be changed during subroutine process or interrupt service, it should be saved/restored with the PUSH/POP instruction. The MBS is set with the SEL instruction. Ex. 1: Clears the MBE to fix memory bank: #### Ex. 2: Selects memory bank 1: SET1 MBE ; MBS → 1 SEL MB1 ; MBS → 1 #### 2.1.2 Data memory addressing mode The $\mu$ COM75X architecture adopted for $\mu$ PD75268 provides seven addressing modes listed in Fig. 3.1-2 and Table 3.1-1 to efficiently address the data memory space for each bit length of the data to be processed, thus enabling efficient programming. (1) One bit direct addressing (mem.bit) In this addressing mode, each bit of the entire data memory space is directly addressed with operands. In MBE=0 mode, the memory bank is fixed to MB=0 if the address specified by an operand is 00H-7FH, and to MB=15 if the specified address is 80H-FFH. In MBE=0 mode, therefore, both general-purpose RAM area (000H-07FH) and peripheral hardware area (F80H-FFFH) are addressable. In MBE=1 mode, memory bank can be specified by the MBS register, allowing expansion of addressable data memory space. This addressing mode is available with four instructions: i.e., Set Bit and Reset Bit (SET1/CLR1) and Test Bit (SKT/SKF) instructions. EX.: Sets FLAG1, resets FLAG2, and tests if FLAG3 IS ZERO: FLAG1 EQU 03FH.1 ; bit 1 of address 3FH FLAG2 EQU 087H.2 bit 2 of address 87H FLAG3 EQU 0A7H.0 : bit 0 of address A7H SET1 MBE MBE 1 MBS SEL MB0 0 FLAG SET1 FLAG 1 FLAG2 -CLR1 FLAG2 0 Fig. 3.1-2 Data Memory Configuration and Addressing Range of each Addressing Mode | | | 1C3H | 1C2H | 1C1H | 1C0H | |--------------------------|-------|-----------------|---------------|------------|-------------| | | | 1C7H | 1C6H | 1C5H | 1C4H | | | | 1CBH | 1CAH | 1C9H | 1C8H | | | | 1CFH | 1CEH | 1DDH | 1CCH | | | | 1D3H | 1D2H | 1D1H | 1D0H | | | | 1D7H | 1D6H | 1D5H | 1D4H | | | | 1DBH | 1DAH | 1D9H | 1D8H | | | | 1DFH | 1DEH | 1DDH | 1DCH | | | | 1E3H | 1E2H | 1E1H | 1E0H | | | | 1E7H | 1E6H | 1E5H | 1E4H | | | | 1EBH | 1EAH | 1E9H | 1E8H | | | | 1EFH | 1EEH | 1EDH | 1ECH | | | | 1F3H | 1F2H | 1F1H | 1F0H | | | | 1F7H | 1F6H | 1F5H | 1F4H | | | | 1FBH | 1FAH | 1F9H | 1F8H | | | | 1FFH<br>(PORTH) | 1FEH<br>(KS1) | 1FDH<br>(K | 1FCH<br>S0) | | | 1 bit | 0 | 0 | 0 | 0 | | Number of<br>Manipulable | 4 bit | 0 | 0 | 0 | 0 | | Bits | 8 bit | 0 | | 0 | | Note 1: KS0, KS1: Key Scan Register Note 2: PORTH: High voltage and high current output port (shared with digit outputs) Fig. 3.1-3 Display Data Memory Configuration $\mu\text{PD75268}$ Table 3.1-1 Addressing Mode | Addressing mode | Identifier | Address to specify | | | | | |------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|--| | 1bit direct<br>addressing | mem.bit | This is the bit (specified by bit) of the address specified by MB and mem. Where, | | | | | | | | MBE=0 { when mem=00H to 7FH, when mem=80H to FFH, | MB=0<br>MB=15 | | | | | | | MBE=1 | MB=MBS | | | | | 4-bit direct addressing | mem | Addressing specified by MB and mem. Where, | | | | | | | | MBE=0 when mem=00H to 7FH, when mem=80H to FFH, | MB=0<br>MB=15 | | | | | | | MBE=1 | MB=MBS | | | | | 8-bit direct<br>addressing | | Addressing specified by MB and mem (mem is even address). Where, | | | | | | | | MBE=0 when mem=00H to 7FH, when mem=80H to FFH, | MB=0<br>MB=15 | | | | | | | MBE=1 | MB=MBS | | | | | 4-bit register indirect addressing | @ HL | Address specified by MB and HL. Where, MB=MBE MBS | | | | | | | @ DE | Address specified by DE of memory bank 0. | | | | | | | @ DL | Address specified by DL of memory bank 0. | | | | | | 8-bit register<br>indirect<br>addressing | @ HL | Address specified by MB and HL<br>Where, MB=MBE MBS and bit 0 of the L register is ignored. | | | | | | Bit manipulation addressing | fmem.bit | The bit (specified by bit) of the address specified by fmem. Where fmem { FB0H to FBFH (hardware relating to interrupts) FF0H to FFFH (I/O ports) | | | | | | | pmem.@ L | The bit specified by the lower 2 bits of the L register whose address is specified by the higher 10 bits of pmem and higher 2 bits of the L register. Where, pmem=FC0H to FFFH | | | | | | | @ H+mem.bit | The bit (specified by bit) of the address specified by MB, H, and lower 4 bits of mem. Where, $$ MB=MBE.MBS | | | | | | Stack addressing | | Address specified by the SP of the memory bank 0. | | | | | ## (2) Four-bit direct addressing (mem) This addressing mode allows each 4-bit on the entire data memory space to be directly addressed with operand of instruction. In the MBE=0 mode, addressable areas are fixed to the general-purpose RAM area (000H–07FH) and peripheral hardware area (F80H–FFFH) similar to the one-bit direct addressing mode. In MBE=1 mode, the entire data memory area can be addressed with the MBS register setting. This addressing mode is applicable to the MOV, XCH, INCS, IN, and OUT instruction. Ex. 1: Reads the value of Port 4 and stores it to DATA1: DATA1 EQU 5FH : DATA1 is address 5FH. CLR1 MBE ; MBE → 0 IN A, PORT4 ; A → PORT4 MOV DATA1, A ; (DATA1) → A Ex. 2: Outputs data at Buff to Port 6: ``` BUFF EQU 11AH BUFF is address 11AH. SET1 MBE MBE-1 MBS-1 SEL MB<sub>1</sub> A→ (BUFF) MOV A, BUFF MBS - 15 SEL MB15 OUT PORT6, A PORT6 - A ``` Note: Program efficiency will be reduced if, as shown in example 2, data pertaining to I/O ports is stored in the general-purpose RAM in Bank 1. Updating to the MBS will not be required in programming (as shown in the example 1) if the port data is stored in address area 00H to 7FH in Bank 0. #### (3) Eight-bit direct addressing (mem) In this addressing mode, each 8-bit on the entire data memory area can be directly addressed with operand of instruction. Only even-numbered addresses can be specified by operands. Four-bit address data that is incremented by one are paired to be 8-bit processed by the 8-bit accumulator (XA register pair). The specified memory banks are the same as those specified in the 4-bit direct addressing mode. This addressing mode is applicable to the MOV, XCH, IN, and OUT instructions. Ex. 1: Transfers 8-bit data on Ports 4 and 5 to addresses 20H and 21H. Ex. 2: Fetches the 8-bit data loaded in the serial interface's shift register (SIO), and sets transfer data and start transfer ``` SEL MB15 ; MBS → 15 XCH XA, SIO ; XA → SIO ``` # (4) Four-bit register indirect addressing (@rpa) In this addressing mode, each 4-bit on the data memory space are indirectly addressed by a data pointer (general-purpose register pair) which is specified by an operand of instruction. Three register pairs are available for data pointer: the HL register pair which can specify the entire data memory area by MB=MBE • MBS specifying; the DE and the DL register pairs which each always specifies memory bank zero with no regard to the MBE and MBS setting. Effecient programming is possible by choosing the appropriate data pointer according to the memory bank to be used. Ex. 1: Transfers data in addresses 50H to 57H to addresses 110H to 117H: ``` DATA1 FOU 57H 117H DATA2 FOLL MBE SET1 MBE- 1 SEL MB<sub>1</sub> MBS- 1 MOV D. # DATA1 SHR 4 MOV HL. # DATA2 and 0FFH : HL<del>→</del> 17H A - (DL) LOOP: MOV A, @ DL XCH A, @ HL A → (HL) L - L-1 DECS - RR LOOP ``` The addressing mode in which the HL register pair is used as a data pointer is used for data transfer, arithmetic operations, comparsion, I/O operations, and other purposes. The addressing mode using the DE or DL register pair is used for the MOV or XCH instructions. When this addressing mode is combined with an Increment or Decrement instruction for general-purpose registers or register pairs, the RAM address on the data memory space can be freely updated as shown in Fig. 3.1-3. ``` Ex. 2: Compares the data in addresses 50H to 57H with those in addresses 110H to 117H. ``` ``` DATA1 EQU 57H DATA2 EQU 117H SET1 MBE SEL MB<sub>1</sub> MOV D, # DATA1 SHR 4 HL, # DATA 2 and 0FFH MOV LOOP MOV A, @DL SKE A, @HL A = (HL)? BR NO NO DECS BR LOOP ``` # Ex. 3: Clears the data memory area 04H to FFH. ``` SEL MB0 MOV XA, # 00H MOV HL, # 04H LOOP: MOV @HL, A (HL) - A INCS LOOP BR INCS + H+1 Н BR LOOP ``` Fig. 3.1-5 Method of General-Purpose RAM Address modification # (5) 8-bit register indirect addressing (@HL) This addressing mode indirectly specifies all the data memory space in 8-bit units by using the data pointer (HL register pair). The 4-bit data at the address setting data pointer bit 0 (L register bit 0) to 0 and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register) for 8-bit processing. The memory banks specified in the addressing mode are the same as those when the HL register is specified in the 4-bit register indirect addressing mode is applicable to the MOV, XCH, and SKE Instructions. Example 1: To compare the count register (T0) value of timer / event counter 0 with data at addresses 30H and 31H for equality. ``` DATA EQU 30H CLR<sub>1</sub> MBE MOV HL, #DATA MOV XA, TO XA← count register 0 A, @HL SKE A = (HL)? BR NO INCS MOV A. X A ← X SKF A, @HL A = (HL)? ``` ## (6) Bit manipulation addressing This addressing mode is used to perform bit manipulations such as Boolean operation or bit transfer on any bit in all of the data memory space. Although the 1-bit direct addressing mode is applicable only to the bit set, reset, and test instructions, the bit manipulation addressing mode enables bit manipulations such as Boolean operations by using the AND1, OR1, and XOR1 instructions and allows bit test and bit reset by using the SKTCLR instructions. The following three types of bit manipulation addressing modes can be used according to the data memory address to be used: (a) Specific address bit direct addressing (fmem. bit). This addressing mode enables, peripheral hardware that frequently uses bit manipulation, such as input / output ports and interrupt flags, to be operated at any time independently of the memory bank setting. Thus, the addressing mode is applicable to data memory addresses FF0H-FFFH (where input / output ports are mapped) and FB0H-FBFH (where hardware related to interrupts is mapped). For the hardware of the two data memory areas, bit manipulation can be performed in direct addressing at any time as desired regardless of how MBS and MBE are set. Example 1: To test the timer 0 interrupt request flag (IRQT0); if the request flag is set, clear the flag and reset P63. Example 2: To reset P53 if both P30 and P41 are set to 1. - (i) SET1 CY CY <del><−</del> 1 AND1 CY, PORT3.0 CY P3.0 AND1 CY, PORT4.1 CY P4.1 SKT CY CY = 1? BR SETP CLR<sub>1</sub> PORT5.3 P53 - 1 SETP: SET1 PORT5.3 P53 - 1 (ii) SKT PORT3.0 P30 = 1?BR SETP SKT PORT4.1 P41 = 1?BR SETP PORT5.3 CLR<sub>1</sub> STEP: SET1 PORT5.3 P53 <del><−</del> 1 - (b) Specific address bit register indirect addressing (pmem. @L). This addressing mode indirectly specifies each bit of peripheral hardware, such as an input / output port, by using the L register for successive operation. The addressing mode is applicable to data memory addresses FC0H-FFFH. The addressing mode directly specifies the high-order 10 bits of a 12-bit data memory address in the preem operand and indirectly specifies the low-order 2-bit data memory address part and the bit address by using the L register. Thus, 16 bits (four ports) can be manipulated (operated) successively by L register specification. The address mode also enable bit manipulation to be performed at any time independently of how MBE and MBS are set. Example: To output a pulse to each bit of ports 4 to 7 in order. ## (c) Special 1-bit direct addressing (@H + mem. bit) This addressing mode enables bit manipulation to be performed on any bit in all of the data memory space. The addressing mode indirectly specifies the high-order four bits of data memory address of the memory bank specified by MB = MBE MBS by using the H register and directly specifies the low-order 4-bit data memory address part and the bit address in the operands. It enable various types of bit manipulation to be performed on any bit in all of the data memory space. Example: To reset address 32H bit 2 (FLAG3) if both address 30H bit 3 (FLAG1) and address 31H bit 0 (FLAG2) are set to 0 or 1. ``` FLAG1 EQU 30H.3 FLAG2 EQU 31H.0 FLAG3 EQU 32H.2 SEL MB0 ``` MOV H, #FLAG1 SHR 6 CLR1 CY OR1 CY, @H + FLAG1 ; CY ← 0 XOR1 CY, @H + FLAG2 ; CY ← C XOR1 CY, @H+FLAG2 ; CY ← CY-FLAG1 SET1 @H+FLAG3 ; CY ← CY-FLAG2 SKT CY ; CY = 1? CLR1 @H+FLAG3 : FLAG ← 30 ## (7) Stack addressing The stack addressing mode is used for register save and restore during interrupt service or subroutine processing. The processing mode specifies an address by using the 8-bit stack pointer (data memory bank 0). The addressing mode can also be used for register save and restore by executing the PUSH and POP instructions. Example 1: To save and restore register in subroutine processing. RET Example 2: To transfer the HL register pair contents to the DE register pair. ``` PUSH HL POP DE ; DE← HL ``` Example 3: To branch to the address indicated by [XABC] register. PUSH BC PUSH XA RET ; Branch to XABC address #### 3.2 Memory Mapped I / O The μPD75268 adopts memory mapped I/O where peripheral hardware such as input/ports and timers is allocated to addresses F80H-FFFH of the data memory space as shown in Fig. 3.2–2. Thus, peripheral hardware is controlled entirely by memory operation instructions rather than special instructions. (To easily understand programs, some hardware control mnemonics are provided.) The display data memory, key scan register, port H mapped to addresses 1C0H to 1FFH are to be manipulated by specifying memory bank 1. Table 3.2-1 lists the addressing modes that can be used to operate peripheral hardware. Table 3.2-1 Applicable Addressing Modes during Peripheral Hardware Operation | | Applicable addressing mode | Applicable hardware | | |---------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--| | | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem. bit). | All hardware where bit manipulation can be performed. | | | Bit<br>manipulation | Direct addressing regardless of how MBE and MBS are set. (specification in fmem. bit) | ISTO, MBE<br>IExxx, IRQxxx, PORTn.x | | | | Indirect addressing regardless of how MBE and MBS are set. (specification in pmem. @L) | PORTn.x | | | 4-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem). | All hardware where 4-bit manipulation | | | manipulation | With (MBE=1 and MBS=15), register indirect addressing (specification in @HL). | can be performed. | | | 8-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem), mem must be an even address. | All hardware where 8-bit manipulation can | | | manipulation | With MBE=1 and MBS=15, register indirect addressing (specification in @HL; the L register must contain an even number | be performed. | | | Example: CLR1 | MBE | ; | MBE = 0 | |---------------|---------------|---|------------------------------------------| | SET1 | TM0.3 | ; | Timer 0 starts. | | El | IE0 | ; | INT0 is enabled. | | DI | IE1 | ; | INT1 is disabled. | | SKTCLR | IRQ2 | ; | INT2 request flag is tested and cleared. | | SET1 | CY | | | | SET1 | PORT4. @L | ; | Port 4 is set. | | AND1 | CY, Port4. @L | | | | IN | A, PORT0 | ; | A ← port 0 | | OUT | PORT4, XA | ; | Port 5, 4 | | | | | | Figs. 3.2-1 to 3.2-3 shows the $\mu$ PD75268 I/O map. The columns in the figures mean: ## · Abbreviation: Name indicating internal hardware address. It can be entered in the instruction operand field. ### R/W Indicates whether the hardware device can be read or written. - R/W: Read and write are enabled. - Read only is enabled. - W : Write only is enabled. ### · Number of bits that can be manipulated: Indicates the number of bits that can be processed when the hardware device is operated. - O: Bit manipulation is enabled in 1-4, 4-, or 8-bit units as specified in the column. - Δ. Only some bits can be manipulated. See Remarks for the bits that can be manipulated. - -: Bit manipulation cannot be performed in 1-, 4-, or 8-bit units as specified in the column. ### · Bit manipulation addressing: Indicates the applicable bit manipulation addressing for performing bit manipulation on the hardware device. ## Table 3.2-2 µPD75268 I/O Map (1/3) | Address | Hardware (Symbol) | | ool) | R/W | | nber of bi | | Addressing mode | Remarks | | |---------|--------------------------------------------|--------------------------------------------|---------------|---------|-------|------------|---------|------------------------------------|----------|-------------------------------------------| | | b3 | b2 | b1 | ь0 | | 1 bit | 4 bits | 8 bits | | | | F80H | Stack | pointer | r (SP) | | R/W | | | | | Bit 0 is fixed to 0. | | | | | | | l L/W | _ | - | " | | | | F85H | | interva<br>registe | | 1) | w | | 0 | _ | mem.bit | Only bit 3 can be bit manipulated. | | F86H | Basic | interva | l timer | (BT) | R | _ | _ | 0 | | | | | | | | | " | _ | _ | ~ | | | | F88H | Displa<br>(DSP | ay mode<br>M) | e regist | er | w | | 0 | _ | | | | F89H | Dimm<br>(DIMS | ner sele<br>S) | ct regis | ter | w | _ | 0 | _ | | | | F8AH | KSF | Digit s<br>(DIGS | elect re | egister | R/W | Δ | 0 | _ | mem.bit | Only bit 3 is testable. | | F98H | Watch mode register (WM) | | w | _ | | 0 | | | | | | FA0H | Timer/event counter #0 mode register (TM0) | | w | Δ | | 0 | mem.bit | Only bit 3 can be bit manipulated. | | | | | | | | | | | | | | · | | FA4H | | Timer/event counter #0 count register (T0) | | R | _ | | 0 | | | | | | Count | | | , n | _ | | | | | | | FA6H | | /event o | | | w | | _ | 0 | | | | FB0H | 0 | IST0 | MBE | 0 | R/W | 0 | 0 | | fmem.bit | | | | | am stat<br>(PSW) | us | | R | _ | _ | 0 | | · | | FB2H | IME | | $\overline{}$ | | w | | _ | | | El and DI instruction are used | | FB3H | | essor clo | | ntrol | w | _ | 0 | | | | | FB4H | INT0 | mode re | egister | (IM0) | w | _ | 0 | _ | | Bit 2 is fixed to 0. | | FB5H | INT1 | mode re | egister | (IM1) | W | _ | 0 | | | Bits 3, 2, 1 are fixed to 0 | | FB7H | | m clock<br>er (SCC | | ol | w | Δ | _ | _ | | Only bits 3 and 0 can be bit manipulated. | # Table 3.2-2 µPD75268 I/O Map (2/3) | Address | Ha | ardware | (Syml | pol) | R/W | | nber of bi | | Addressing mode | Remarks | |---------|--------|-------------------|---------------|--------|--------|-------|------------|--------|-----------------|------------------------------------| | | b3 | b2 | b1 | b0 | - | 1 bit | 4 bits | 8 bits | | | | FB8H | IE4 | IRQ4 | IEBT | IRQBT | R/W | 0 | 0 | _ | fmem.bit | | | FBAH | _ | _ | IEW | IRQW | R/W | 0 | 0 | _ | | | | FBBH | IEKS | IRQKS | _ | _ | R/W | 0 | 0 | _ | | | | FBCH | _ | - | IET0 | IRQT0 | R/W | 0 | 0 | - | | | | FBDH | _ | | IESIO | IRQSIO | R/W | 0 | 0 | | | | | FBEH | IE1 | IRQ1 | IE0 | IRQ0 | R/W | 0 | 0 | _ | | | | FBFH | _ | | _ | IRQ2 | R/W | 0 | 0 | | * | | | FE0H | | operat<br>er (SIO | | de | W | Δ | _ | 0 | mem.bit | Only bit 3 can be bit manipulated. | | FE4H | | I/O shi | ift regis | ster | 544 | | _ | | | | | | (SIO) | | | | R/W | _ | _ | 0 | | | | FE8H | PM33 | PM32 | PM31 | PM30 | | _ | | | | | | | | node re | | | w | | | 0 | | | | | PM63 | PM62 | PM61 | PM60 | | | | | | | | FECH | _ | PM2 | _ | _ | | | _ | | - | | | | | node re<br>B (PM | | | w | | 0 | | | | | | _ | _ | PM5 | PM4 | | | | | | | | FF0H | Port 0 | (POR | T0) | | R | 0 | 0 | | fmem.bit | | | FF1H | Port 1 | (POR | T1) | | R | 0 | 0 | - | pmem.@L | | | FF2H | Port 2 | (POR | T2) | | R/W | 0 | 0 | | | | | FF3H | Port 3 | (POR | T3) | | R/W | 0 | 0 | | | | | FF4H | Port 4 | (POR | T4) | | R/W | 0 | 0 | 0 | | | | FF5H | Port 5 | (POR | T5) | | R/W | 0 | 0 | | | | | FF6H | Port 6 | (POR | T6) | | R/W | 0 | 0 | _ | | | | 1C0H+4n | | ay data | | ry: | R/W | 0 | 0 | 0 | mem.bit | | | 1C1H+4n | 50-5 | 7 (n=0- | 15) | | IT/VV | 0 | 0 | | | | | 1C2H+4n | | ay data | | ry: | R/W | 0 | 0 | 0 | | | | 1C3H+4n | 58-5 | 15 (n=0 | <i>i</i> -15) | | FT/ VV | 0 | 0 | | | | | 1FCH | Key s | can reg | gister ( | KS0) | R/W | 0 | 0 | 0 | | | | 1FDH | | | | | | 0 | 0 | | | | | 1FEH | Key s | can reg | gister ( | KS1) | R/W | 0 | 0 | 0 | | | | 1FFH | Port I | l (POR | TH) | | R/W | 0 | 0 | 0 | | | #### 4. INTERNAL CPU FUNCTIONS ## 4.1 Program Counter (PC) 13 bits This is a 13-bit binary counter that stores address information of the program memory. μPD75268 | PC12 | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | ĺ | |------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| |------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| ## Fig. 4.1-1 Program Counter Configuration When an instruction is executed, the program counter is automatically incremented according to the number of bytes of the executed instruction. When branch instruction (BR, BRCB) is executed, the contents of immediate data or register pair indicating address to be branched are loaded to all of some or the bits of the PC. When a call instruction (CALL, CALLF) is executed or when a vector interrupt is generated, the contents of the PC (return address that has been incremented to fetch the next instruction) are saved to the stack memory and then the corresponding addresses to which the program execution are to be jumped are loaded. When a return instruction (RET, RETS, RETI) is executed, the contents of the stack memory are set to PC. Generation of internal reset signal (RES) sets the lower 5 bits of address 0000H of the program memory to the PC12 to PC8. It also sets the contents of address 0001H to PC7 to PC0. Thus the PC is initialized. For this reason, program execution can be started from any address. #### 4.2 Program Memory (ROM) ### 8,064 words x 8 bits (µPD75268) The program memory is mask programmable ROM consisting of 8064 words x 8 bits and stores programs, interrupt vector table, GETI instruction reference table, and table data. The program memory is addressed by using the program counter. Table data can be referenced by using the table reference instruction (MOVT). Figures 4.2-1 and 4.2-2 show the address range in which a branch can be made by using branch instruction or subroutine call instruction. In addition to the instructions, the BR PCDE and BR PCXA instructions can be used for a branch to address where only the low-order eight bits of PC are changed. The program memory addresses are 0000H-1F7FH. The following addresses are specially assigned: (All area except address 0000H or 0001H can be used as normal program memory.) 0000H to 0001H (000H to 001H) This address area is used as vector address table to which the program start address when a reset signal is applied and set values of MBE are written. Program execution can be started from any address after reset. 0002H to 000FH (002H to 00FH) This address area is used for vector address table to which the program start address by vector interrupt and the set values of MBE are written. Interrupt service can be started from any address. 0020H to 007FH (020H to 07FH) This is a table area referenced by the GETI instrucion\*. \*The GETI instruction is used to execute any 2-3-byte instruction in one byte. Using this instruction, the number of program bytes can be reduced. Remarks: The BR \$addr instruction enables a branch to the address indicated by PC contents +16 to PC contents +2 or PC contents - 1 to PC contents - 15 regardless of the block boundaries. Fig. 4.2-2 Program Memory Map (μPD75268) ## 4.3 Data Memory ... 512 x 4 The data memory consists of up to 512 words x 4 bits of static RAM. It is used for processing data storage or as stack memory space for use in subroutine or interrupt services. Because it is a static RAM, its data can be retained when the CPU operation stopped, standby mode. This is effective for long time data memory retention with battery back-up. Fig. 4.3-1 shows data memory map for the $\mu$ PD75268. The data memory has bank configuration. A bank has up to 256 word x 4 bits. There are two memory banks; Memory Bank 0 Memory Bank 1 Note the on-chip peripherals are memory – mapped in the bank 15. A memory bank is selected by the 4-bit Memory Bank Select register (MBS=0, 1, 15) when bank selection is enabled by the Memory Bank Enable flag (MBE=1). When bank selection is disabled (MBE=0), bank 0 or bank 15 is automatically selected by the current addressing mode. Addresses in a bank are addressed by 8-bit immediate data, register pair, etc.. The data memory has one-word four-bit configuration, but 1/4/8-bit unit operation is possible by powerful addressing modes. Details for memory bank selection and addressing, see Section 2.1. Special area in the data memory are also used as general purpose register (bank 0:000H to 01FH), stack memory (bank 0:000H to 0FFH), and display data memory (bank 1:1C0H to 1FFH). Note the bank 15 has no data memory but has on chip peripherals memory mapping area. Fig. 4.3-1 Data Memory Map Each address of the data memory consists of 4 bits; however, the data memory can be manipulated in 8-bit units using 8-bit memory manipulation instructions and in bit units using bit manipulation instructions. Even addresses only must be specified for 8-bit memory manipulation instructions. When doing a reset during operating mode (not standby), the data memory contents may become undefined due to the possibility of reset during memory access. Therefore, the memory should be initialized at the beginning of every application program (RAM clear). Example: Clears RAM locations 000H to 1FFH. (FFH remains in the HL register, however): | LOOP1: | SET1<br>SEL<br>MOV<br>MOV<br>MOV | MBE<br>MB1<br>HL, #00H<br>XA, #00H<br>@HL, A | : Clears 100H to 1FFH | |--------|----------------------------------|----------------------------------------------|-----------------------| | | INCS<br>BR<br>INCS<br>BR | L<br>LOOP1<br>H<br>LOOP1 | , 5,5,5,6 | | LOOP2: | SEL<br>MOV<br>DECS<br>BR | MB0<br>@HL, A<br>L<br>LOOP2 | ; Clears 00H to FFH | LOOP2 DECS H BR | | | 1C3H | I<br>1C2H<br>I | 1C1H | 1 1C0H | | |----------------------------------|-------|------------------|------------------|------------------|------------------|--| | | | 1C7H | 1C6H | 1C5H | 1C4H | | | | | 1CBH | 1 1CAH | 1C9H | 1C8H | | | | | 1CFH | I<br>1CEH | 1DDH | 1CCH | | | | | 1D3H | I<br>1D2H<br>I | 1D1H | 1D0H | | | | | 1D7H | 1 D6H | 1D5H | 1D4H | | | | | 1DBH | I<br>1DAH<br>I | 1D9H | 1D8H | | | | | 1DFH | 1DEH | 1DDH | 1DCH | | | | | 1E3H | 1E2H | 1E1H | 1E0H | | | | | | 1<br>1E6H | 1E5H | 1E4H | | | | | 1EBH | I<br>1EAH | 1E9H | 1E8H | | | | | 1EFH | 1EEH | 1EDH | 1ECH | | | | | 1F3H | I<br>1F2H<br>I | 1F1H | I<br>1F0H | | | | | 1F7H | ı<br>1F6H<br>L | 1F5H | 1F4H | | | | | 1FBH | 1FAH | 1F9H | 1F8H | | | | | 1FFH<br>(PORTH) | 1FEH<br>(KS1) | 1FDH | 1FCH<br>(KS0) | | | Number of | 1 bit | 0 | 0 | 0 | 0 | | | Number of<br>Manipulable<br>Bits | 4 bit | 0 | 0 | 0 | 0 | | | DIES | 8 bit | | 0 | 0 | | | | | | 1C0H +<br>4n + 3 | 1C0H +<br>4n + 2 | 1C0H +<br>4n + 1 | 1C0H +<br>4n + 0 | | | | | | | | | | Note 1: KS0, KS1: Key Scan Register Note 2: PORTH: High-voltage and high current output port also used for digit output. Note 3: n = 0 to 15 ## Fig. 4.3-3 Display Data Memory Configuration μPD75268 Example: Clears 1C0H to 1FFH of the Display Data Memory. SET1 MBE SEL MB1 MOV HL, #0C0H MOV XA, #00H LOOP: MOV @HL, XA ; Clears the Display data Memory in 8-bit units. INCS L INCS L BR LOOP INCS H BR LOOP ### 4.4 General Purpose Registers - Eight x Four Bits The general purpose registers are eight 4-bit registers (B, C, D, E, H, L, X, and A) mapped in specific addresses of the data memory. Every general purpose register is handled in 4-bit units; register pairs BC, DE, HL, and XA are also used for 8-bit manipulation. In addition to DE and HL, registers D and L are also paired (DL), and the three register pairs can be used for data pointers. The general purpose register area can be addressed and accessed as normal RAM regardless of whether or not it is used for registers. | Х | | А | | |---|-----|---|-----| | | 01H | | 00H | | Н | | L | | | | 03H | | 02H | | D | | E | | | | 05H | | 04H | | В | | С | | | | 07H | | 06H | Figure 4.4-1 General Purpose Register Configuration (When 4-bit processing is performed) | XA | 00H | |----|-----| | HL | 02H | | DE | 04H | | ВС | 06H | Figure 4.4-2 General Purpose Register Configuration (When 8-bit processing is performed) Figure 4.4-3 Register Pair Configuration #### 4.5 Accumulator The μPD7500X uses the A register and XA register pair for accumulators. The A register is used as the main register during execution of 4-bit data processing instructions; the XA register pair is used as the main register pair during execution of 8-bit data processing instructions. The carry flag (CY) is used for a bit accumulator during execution of bit manipulation instructions. Figure 4.5-1 Accumulator ## 4.6 Stack Pointer (SP) - Eight Bits The μPD75268 uses general purpose RAM for stack memory (LIFO). The stack pointer (SP) is an 8-bit register which holds top address information of the stack area. The stack area addresses are 000H-0FFH of memory bank 0 regardless of how MBE and MBS are set. SP is decremented before data is saved in the stack memory (write operation); it is incremented after data is restored from the stack memory (read operation). Fig. 4.6-2 shows data saved in and restored from the stack memory when stack operations are performed. An initial value is set in SP by using an 8-bit memory operation instruction to determine the stack area to be used. The SP contents can also be read. SP0 is always set to 0. It is recommended that the initial value of SP should be set to 00H so that the stack area be used is starting at the most significant address of data memory bank 0 (0FFH). When the RESET signal is generated, the SP contents become undefined. Be sure to initialize SP to the desired value at the start of the program. Example: To initialize SP. SEL MB15 ; or CLR1 MBE MOV XA, #00H MOV SP, XA ; SP ← 00H Figure 4.6-1 Stack Pointer Configuration # (a) Data Saved in Stack Memory ## (b) Data Restored from Stack Memory Figure 4.6-2 Data Saved / Restored in Stack Operation (µPD75268) ## 4.7 Program Status Word (PSW) - Eight Bits The program status word (PSW) consists of flags closely related to processor operation. PSW is mapped in data memory addresses FB0H and FB1H. Two bits of address FB0Hcan be operated by using a memory operation instruction. Figure 4.7-1 Program Status Word Configuration Table 4.7-1 PSW Flags Saved and Restored when Stack Operation is Performed | | Saved or restored flag | | |---------|------------------------------------------|---------------------------| | Save | During CALL, CALLF instruction execution | MBE is saved | | Save | During hardware interrupt | All PSW bits are saved | | Restore | During RET, RETS instruction execution | MBE is restored | | Hestore | During RETI instruction execution | All PSW bits are restored | ## (1) Carry flag (CY) The carry is a 1-bit flag that shows the occurence of overflow or underflow during execution of an instruction involving carry (ADDC or SUBC). The carry flag also serves as a bit accumulator. Boolean algebra operation is performed between the bit accumulator and data memory specified by a bit address. The result can be stored in the bit accumulator. The carry flag is operated by using dedicated instructions independently of other PSW bits. When the RESET signal is generated, the carry flag becomes undefined. Table 4.7–2 Carry Flag Operation Instructions | | Instructions (mnemonic) | Carry flag processing | |------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------| | Instructions dedicated to carry flag operation | SET1 CY<br>CLR1 CY<br>NOT1 CY<br>SKT CY | CY is set to 1<br>CY is cleared<br>CY is inverted<br>Skip if CY is set to 1 | | Bit Boolean instructions | AND1 CY, mem*.bit OR1 CY, mem*.bit XOR1 CY, mem*.bit | The specified bit and CY are ANDed, ORed, or XORed together | | Interrupt service | During interrupt execution | CY is saved in stack<br>memory in parallel with<br>other PSW bits (eight bits) | | interrupt service | RETI | CY is restored from stack<br>memory in parallel with<br>other PSW bits | Remarks: mem\*.bit indicates any of the following three bit 3 manipulation addressing modes - fmem.bit - pmem.@L - · @H + mem.bit Example: To AND bit 3 of address 3H and P33 together and set the result in CY. SET1 CY ; CY ← 1 CLR1 MBE ; Or SEL MB15 SKT 3FH. 3; Skip if bit 3 of address 3FH is set to 1. CLR1 CY ; CY ← 0 AND1 CY, PORT3.3 ; CY ← CY ↑ P33 (2) Skip flags (SK2, SK1, and SK0) The skip flags store the skip state and are automatically set or reset when the CPU executes instructions. The user cannot directly use the flags as operands. (3) Interrupt status flag (IST0) The interrupt status flag stores the current status of processing being performed. (For details, see Table 4.7-3) Table 4.7-3 Interrupt Status Flag Indication Contents | IST0 | Status of processing being performed | Processing contents and interrupt control | |------|--------------------------------------|---------------------------------------------------------------------------| | 0 | Status 0 | During normal program processing.<br>Every interrupt can be acknowledged. | | 1 | Status 1 | During interrupt processing. No interrupt must be acknowledged. | If an interrupt is acknowledged, the IST0 contents are saved in stack memory as a PSW bit, then automatically IST0 is set to 1. When an RETI instruction is executed, IST0 is set to 0. The interrupt status flag can be operated by using a memory operation instruction. The current status of processing can also be changed under program control. Caution: Before operating the flag, be sure to execute a DI instruction to disable interrupts. After operating the flag, execute an EI instruction to enable interrupts. (4) Memory bank enable flag (MBE) The memory bank enable flag is a 1-bit flag used to specify the address information generation mode of the high-order four bits of a 12-bit data memory address. MBS can be set or reset at any time by using a bit manipulation instruction regardless of memory bank setting. Example: SET1 MBE ; MBE ← 1 CLR1 MBE ; MBE ← 0 When MBE is set to 1, the data memory address space is exceeded and all the data memory space can be addressed. When MBE is reset to 0, the data memory address space is fixed regardless of how MBS is set. (see Fig. 2.1-2.) When the RESET signal is generated, the contents of program memory address 0 bit 7 are set and MBE is initialized automatically. When vectored interrupt service is made, bit 7 of the corresponding vector address table is set and the MBE state during interrupt service is set automatically. During interrupt service, normally MBE is set to 0 and the general purpose RAM of memory bank 0 is used. #### 4.8 Bank Selection Register (BS) The memory bank selection register (MBS) for selecting a memory bank is mapped in the bank selection register (BS). The loworder four bits of BS are fixed to 0 MBS is set by using the SEL MBn instructions. BS can be saved in and restored from the stack area in 8-bit units by using PUSH BS instructions. Figure 4.8-1 Bank Selection Register Configuration ### (1) Memory bank selection register (MBS) The memory bank selection register (MBS), consisting of four bits, stores high-order 4-bit address information of a 12-bit data memory address. The memory bank to be accessed is specified according to the register contents. However, the µPD75268 allows the user to select bank 0, bank 1, or bank 15 only. MBS is set by using the SEL MBn instruction (where n is 0, 1, or 15). The address range applied according to how MBE and MBS are set is as shown in Fig. 2.1-2. When the RESET signal is generated, MBS is initialized to 0. ### 5. PERIPHERAL HARDWARE FUNCTIONS ### 5.1 Digital I/O Ports The µPD75268 contain digital I/O ports: ports 0 to 6 and port H. For the $\mu$ PD75268, memory-mapped input/output is employed; thus, all I/O ports are mapped in the data memory space. Since the data memory manipulation instruction can be applied to each of the I/O ports, bit-manipulated and 8-bit data input/output are possible in addition to 4-bit input/output, allowing the I/O ports to be controlled in serveral ways. | Address | | | | | Symbol | |---------|-----|-----|-----|-----|--------| | | 3 | 2 | 1 | 0 | | | FF0H | P03 | P02 | P01 | P00 | PORT0 | | FF1H | P13 | P12 | P11 | P10 | PORT1 | | FF2H | P23 | P22 | P21 | P20 | PORT2 | | FF3H | P33 | P32 | P31 | P30 | PORT3 | | FF4H | P43 | P42 | P41 | P40 | PORT4 | | FF5H | P53 | P52 | P51 | P50 | PORT5 | | FF6H | P63 | P62 | P61 | P60 | PORT6 | | 1FFH | PH3 | PH2 | PH1 | PH0 | PORTH | | | | | | | | Fig. 5.1-1 Digital I/O Port Data Memory Addresses The I/O port control instruction are as shown in Table 6.1-2. In addition to 4-bit input/output, 8-bit input/output and bit manipulation can be done, allowing the I/O ports to be controlled several ways. Example 1: To test the status of P13 and the output value to Ports 4 and 5 according to the test results: SKT PORT1.3 ; Skips if bit 3 of port 1 is 1. MOV XA, #18H ; XA → 18H String effect MOV XA, #14H ; XA → 14H String effect SEL MB15 ; or, CLR1 MBE OUT PORT4, XA ; Port 5, 4 → XA Example 2: SET1 PORT4.@L ; Of ports 4 to 6, the bit specified by the L register is set to 1. 5.1.1 Types of digital I/O ports and either features and configuration The types of digital I/O ports are as shown in Table 5.1-1. Table 5.1-1 Types of Digital Ports and Their Features | Port name<br>(Symbol) | Function | operation, features | Notes | | | | | | |-----------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Port 0 | 4-bit input | Can be read or tested at any time regardless of the functional mode of shared pins. | The port pins are also used for SI, SO, SCK, and INT4. | | | | | | | Port 1 | · | P10 and P11 have noise eliminate function input. | The port pins are also used for INT0, INT2 and TI0 | | | | | | | Port 3<br>Port 6 | 4-bit input/<br>output. | Can be set for input or output mode in 1-bit units. | Port 6 can incorporate a pull-down resistor (mask option) and its VIH is low; therefore, it is suitable for key input. | | | | | | | Port 2 | | Can be set for input or output mode in 4-bit units. | P23 also used for BUZ. pin. | | | | | | | Port 4<br>Port 5 | | Ports 4 and 5 can paired to enable 8-bit data transfer. | | | | | | | | Port H | 4-bit output | P-ch open-drain high-voltage, high-<br>current output sport. Can directly drive<br>FIPs or LEDs. Pull-down resistors<br>may be built in as mask option. | Shared with T10/S15 to T13/S12 pins. | | | | | | Ports 4, 5 can directly drive LED. P10 and P11 are also used as external vector interrupt input pins, and contain a noise eliminator. PORT H is shared with display output pins (T10/S15 to T13/S12). In Display Off mode (DSPM.3=0), in the same ways as other display outputs, these pins become low level (when internal pull-down reesistors are internally provided) or high impedance (if no pull-down resistor is provided). Therefore, the display mode must be specified by the display mode register (DSPM) before using PORT H. The configuration of each port is shown in Figs. 5.1-1 to 5.4-5. Fig. 5.1-2 Configuration of Ports 0 and 1 (μPD75268) Fig. 5.1-3 Configuration of Ports 3n and 6n (n=0 to 3) ( $\mu$ PD75268) Fig. 5.1-4 Configuration of Ports 2, 4, 5 ( $\mu$ PD75268) Fig. 5.1-5 Configuration of Port H ### 5.1.2 Setting input and output modes The input/output mode of each input/output port is set by using the port mode register as shown in Fig, 5.1-6. The input or output mode can be specified bitwise for port 3 and 6 by using port mode register group A (PMGA). The input or output mode is specified in 4-bit units for ports 2, 4, 5 by using PMGB. When the corresponding bit in the port mode register is set to 0, each port functions as an input port. When the corresponding bit is set to 1, each port functions as an output port. When the output mode is selected by setting the port mode register, at the same time, the contents of output latch are output to output pin. For this reason, setting the contents of output of output latch to the desired value is required before setting the output mode. Each port mode register group (A and B,) can be set by 8-bit memory manipulation instruction. All bits of each port mode register are cleared when an internal reset signal RES is generated, then all output buffers are turned off and all ports are set in input mode. Note: -: Don't care Fig. 5.1-6 Format of Each Port Mode Register ## 5.1.3 Digital I/O port manipulation instructions Since all I/O ports contained in the µPD75268 are mapped to the data memory space, they can be manipulated with all data memory manipulation instructions. Table 5.1.2 summarizes the instructions that are particulary effective to I/O port manipulation and their applicable ranges. #### (1) Bit manipulation instructions Since all digital I/O ports can be addressed with the fixed address bit register direct addressing (fmem.bit) and fixed address bit register indirect addressing (pmem.@L) modes, any individual bit on any port can be manipulated with no regard to the MBE and MBS settings. Example: To OR P50 with P41 together and output the result to P61: SET CY CY-1 AND1 CY, PORT5.0; CY CY A P50 OR1 CY, PORT4.1; CY ← CY VP41 SKT CY BR CLRP SFT1 PORT6.1 ; P61-1 CLRP: CLR1 PORT6.1 (2) Four-bit memory manipulation instructions All four-bit memory manipulation instructions including IN/OUT, MOV, XCH, ADDS, and INCS are usable. Memory bank 15 must be selected prior to execution. Example: Outputs the contents of accumulator to Port 3: MB15 Example: Adds accumulator value to the data on Port 5 and outputs the result: : or CLR1 MBE : P61-0 SFT1 MBE SEL MB15 MOV HL. # PORT5 ADDS A, @HL PORT3, A NOP OUT MOV @HL. A : PORT5 - A Example: Tests if the data on Port 4 is larger than the accumulator value: SET1 MBE SEL **MB15** MOV HL. #PORT4 SUBS A, @HL A < PORT4 NO BR NO YES #### (3) Eight-bit manipulation instructions The IN, OUT, MOV, XCH, and SKE instructions can be used to the ports which allow 8-bit manipulation. Memory bank 15 must be selected prior to instruction execution. Example: Outputs the BC register pair value to the output port specified by the 8-bit data which was input through Ports 4 and 5: SET1 MBE SEL **MB15** IN XA, PORT4 ; XA → port 5, 4 MOV HL. XA HL XA MOV XA, BC XA - BC Port(L) - XA MOV @HL, XA Table 5.1-2 I/O Pin Manipulation Instruction List | | | | PORT0 | PORT1 | PORT2 | PORT3 | PORT4 | PORT5 | PORT6 | PORTH | (3) | | | |-------------------------|------|------------------|-------|---------|-------|----------------|-------|-------|-----------------------|------------------------|-----|--|--| | 4/8-bit IN A, PORTn (1) | | | | | | MOV A, PORTH | | | | | | | | | Input | IN | XA, PORTn (1 | 1 - | - - 0 | | | | | 0 | | | | | | 4/8-bit | OUT | PRTn, A (1 | _ | | | | 0 | | | MOV PORTH, A | | | | | Output | OUT | PORTn, XA (1 | _ | | _ | | 0 | | _ | _ | | | | | 1-bit SET1 PORTn. bit | | PORTn. bit | | _ | | | 0 | | | SET1 PORTH. bit | | | | | Output | SET1 | PORTn. @L (2 | | | | | 0 | | | <u></u> | | | | | | CLR1 | PORTn. bit | _ | _ | | | 0 | | | CLR1 PORTH. bit | | | | | | CLR1 | PORTn. @L (2 | _ | _ | | 0 | | | | <u> </u> | | | | | | SKT | PORTn. bit | | 0 | | | | | | SKT PORTH. bit | | | | | 1-bit | SKT | PORTn. @L (2 | | | | 0 | | | | | | | | | Test | SKF | PORTn. bit | | | | SKF PORTH. bit | | | | | | | | | | SKF | PORTn. @L (2 | | 0 | | | | | | | | | | | | AND1 | CY, PORTn. bit | | | | 0 | | | | AND1 CY, @H+PORTH. bit | | | | | 1-bit<br>Opera-<br>tion | AND1 | CY, PORTn. @L (2 | | 0 | | | | | | - | (4) | | | | | OR1 | CY, PORTn. bit | | | 0 | | | | OR1 CY, @H+PORTH. bit | | | | | | | OR1 | CY, PORTn. @L (2 | | 0 | | | | | | (4) | | | | | | XOR1 | CY, PORTn. bit | | | | 0 | | | | XOR1 CY, @H+PORTH. bit | | | | | | XOR1 | CY, PORTn. @L (2 | | 0 | | | | (4) | | | | | | #### Notes: - 1. Setting MBE=0 or (MBE=1 and MBS=15) is required before executing any of the above instrucions. - 2. Indirectly specify the lower 2 bits of address and bit address by the L register. - 3. MBE=1 and MBS=1 must be selected before execution. - 4. Value 0FH must be set in the H register before execution. #### 5.1.4 Digital I/O port function When a data memory manipulation instruction is executed, the functions of each port and their pins differ depending on the I/O mode setting as shown in Table 5.1-3. As can be understood from the I/O port configuration, this is because data to be placed to the internal bus are data of each pin in the input mode, where as they are data of output latch in the output mode. ## (1) Function in the input mode When executing a test instruction (such as SKT instruction), or an instruction used to input port data into the internal bus in 4 or 8 bits (such as IN, OUT, operation instruction, and compare instruction), the data of the respective pins are manipulated. When executing an instruction (OUT or MOV instruction) used to transfer the contents of the accumulator to port, the data of the accumulator is latched by the output latch. The output buffer remains off. When the XCH instruction is executed, data of each port pins are input to the accumulator are latched to the output latch. The output buffer remains off. When executing the INCS instruction, the 4-bit data of each port pins incremented by 1 is latched to the output latch. The output buffer remains off. When executing an instruction that rewrites the data memory in bit units such as SET1, CLR1, and SKTCLR instructions, the specified data can be rewritten as instructed by the instruction; however, the contents of output latch of other bits becomes undefined. ## (2) Function in the output mode When executing an instruction to input port data into the internal bus in 4 or 8 bits using the test or bit input instruction by which the contents of the accumulator are transferred in 4 or 8 bits, data of the output latch is rewritten and at the same time, it is output from the pins. When the XCH instruction is executed, the contents of the output latch are transferred to the accumulator and the contents of the accumulator are latched to the output latch and output from the pins. When the INCS instruction is executed, the contents of the output latch incremented by 1 is latched to the output latch and output from the pins. When a bit output instruction is executed, the bit of the specified output latch is rewritten and output from the pin. Table 5.1-3 I/O Port Manipulation | Instruction | Port and pin function | | | | | | | | |-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|--|--|--|--|--| | Instruction | Input mode | Output mode | | | | | | | | SKT ① SKF | Tests data of pin | Tests data of output latch | | | | | | | | AND1 CY, O<br>OR1 CY, O<br>XOR1 CY, O | Performs logical operation between data of pin and CY | Performs logical operation between data of output latch and CY | | | | | | | | IN A, PORTn<br>IN XA, PORTn<br>MOV A, @HL<br>MOV XA, @HL | Transfers data of pins to accumulator | Transfers data of output latch to accumulator | | | | | | | | ADDS A, @HL . ADDC A, @HL SUBS A, @HL SUBC A, @HL AND A, @HL OR A, @HL XOR A, @HL | Performs logical operation between data of pins and contents of accumulator | Performs logical operation between data of output latch and contents of accumulator | | | | | | | | SKE A, @HL | Compares data of pins and contents of accumulator | Compares data of output latch with contents of accumulator | | | | | | | | OUT PORTn, A<br>OUT PORTn, XA<br>MOV @HL, A<br>MOV @HL, XA | Transfers contents of accumulator to output latch (Output buffer remains off) | Transfers contents of accumulator to output latch and outputs from pins | | | | | | | | XCH A, PORTN<br>XCH XA, PORTN<br>XCH A, @HL<br>XCH XA, @HL | Transfers data of pins to accumulator and transfers contents of accumulator to output latch (output buffer remains off) | Exchanges data between output latch and accumulator | | | | | | | | INCS PORTn<br>INCS @HL | Latches data of pins plus 1 to output latch | Increments the contents of output latch by 1 | | | | | | | | SET1 ① CLR1 ①, CY MOV1 ① SKTCLR ① | Rewrites output latch of the specified bit as instructed by instruction, but output latches for other bits become undefined | Changes output pin state in accordance with the instruction | | | | | | | Note: 1 in the column of instruction denotes two addressing modes: PORTn.bit and PORTn.@. - 5.1.5 Digital I/O port input/output timings - Fig. 5.1-7 shows the data output timing to output latch and the output latch data read timing into the internal bus. - (a) Reading data by one-machine cycle instruction (b) Reading data with two-machine cycle instruction (c) Latching data with one-machine cycle instruction (d) Latching data with two-machine cycle instruction (output pin) Fig. 5.1-7 Digital I/O Port Input/Output Timing #### 5.2 Clock Generator The clock generator supplies clocks to the CPU and on-chip peripherals and controls CPU operation modes. ### 5.2.1 Clock generator configuration The clock generator configuration is shown in Fig. 5.2-1. Notes: 1. f<sub>x</sub>: Mainsystem clock frequency 6. \* denotes instruction execution. Subsystem clock frequency System clock frequency System clock frequency Processor clock control register System clock control register Fig. 5.2-1 Block Diagram of Clock Generator ### 5.2.2 Clock generator function and operation The clock generator produces the following clocks and controls CPU operating modes such as standby: - Main system clock fx - Subsystem clock fxT - CPU clock φ - Clock to peripheral hardware The clock generator operates according to how the processor clock control register (PCC) and system clock control register (SCC) are set, as described below: - (a) When the RESET signal is generated, the minimum speed mode of the main system clock (15.3 μ/4.19 MHz) is selected. (PCC = 0 and SCC = 0) - (b) When the main system clock is selected, one of three CPU clock frequencies can be selected (0.95 μs, 1.91 μs, and 15.3 μs/ 4.19 MHz) by setting PCC. - (c) When the main system clock is selected, the standby mode (STOP or HALT) can be used. - (d) Subsystem clock is selected by setting SCC.0, and operation can be performed in a very low-speed and low current consumption (122 μs/32.768 kHz). In this case, the PCC setup value does not affect the CPU clock. - (e) When the subsystem clock is selected, main system clock oscillation can be stopped by setting SCC.3. The HALT mode can also be used, but the STOP mode cannot be used. (Subsystem clock oscillation cannot be stopped). - (f) The main system clock is divided to generate a clock supplied to peripheral hardware. The subsystem clock can be supplied directly only to the watch timer. Thus, the watch function can continue operation in the standby mode. - (g) When subsystem clock is selected, the watch timer can continue normal operation. However, the FIP controller driver will not operate. When the main system clock is stopped, other hardware devices cannot be used because they operate according to the main system clock. - (1) Processor clock control register (PCC) PCC consists of four bits; the low-order two bits are used to select CPU clock $\phi$ , and the high-order two bits are used to control CPU operation mode. (See Fig. 5.2-2.) When bit 3 or 2 is set to (1), the standby mode is set. When the standby mode is released by the standby mode release signal, automatically bits 3 and 2 are cleared and the normal operating mode is entered. The low-order two bits of PCC are set by using a 4-bit memory operation instruction (the high-order two bits are set 0). Bits 3 and 2 are set to (1) by using STOP and HALT instructions respectively. The STOP and HALT instructions can always be executed independently of the MBE contents. CPU clock can be selected only during main system clock operation. When the $\mu$ PD75268 is operated on the subsystem clock, the low-order two bits of PCC becomes invalid, and the CPU clock is fixed to $f_{\chi \gamma}/4$ . The stop instruction is also enabled only during main system operation. Example 1: To set a machine cycle to 0.95 µs (4.19) MHz). SEL MB15 MOV A, #0011B MOV PCC. A Example 2: To set STOP mode. (Be sure to enter a NOP instruction following the STOP or HALT instruction.) STOP NOP When the RESET signal is generated, PCC is cleared. Figure 5.2-2 Processor Clock Control Register Format (2) System clock control register (SCC) SCC consists of four bits; the least significant bit is used to select CPU clock, and the most significant bit is used to control (stop) main system clock oscillation. (See Fig. 5.2–3.) SCC.0 and SCC.3 exist at the same data memory address; the bits cannot be changed at the same time. Thus, SCC.0 and SCC.3 are set by using a bit operation instruction. SCC.0 and SCC.3 can always be operated independently of the MBE contents. Main system clock oscillation can be stopped by setting SCC.3 only during subsystem clock operation. Main system clock oscillation is stopped by using the STOP instruction during main system clock operation. When the RESET signal is generated, SCC is cleared. Figure 5.2-3 System Clock Control Register Format Caution 1: Changing the system clock requires a maximum of 1/f<sub>XT</sub> time. To stop main system clock after changing the subsystem clock, set SCC.3 after the machine cycle or cycles listed in Table 5.2–1. - 2: Even if oscillation is stopped by setting SCC.3 during main system clock operation, normal STOP mode is not entered. - 3: When SCC.3 is set to 1, X1 input is connected internally to V<sub>SS</sub>, to avoid leakage current due to crystall oscillator. When the external clock is used in main system clock, do not set SCC.3 to 1. - 4: When the system clock is switched to subsystem clock it is necessary to disable any interrupt during the time given in table 5.2-1. ## (3) System clock oscillators The main system clock oscillator uses a crystal oscillator (4.194304 MHz standard) or cermanic oscillator connected to the X1 and X2 pins. An external clock can also be input. Figure 5.2-4 External Circuit to Main System Clock Oscillator Caution: When an external clock is input, the STOP mode cannot be set because the X1 pin is connected to V<sub>SS</sub> in the STOP mode. The subsystem clock oscillator uses a crystal oscillator (32.768 kHz standard) connected to the XT1 and XT2 pins. An external clock can also be input. Figure 5.2-5 External Circuit to Subsystem Clock Oscillator (4) Frequency divider The frequency divider divides the main system clock oscillator output (f<sub>x</sub>) and generates various clocks. 5.2.3 System clock and CPU clock setting (1) Time required to change system and CPU clocks The system and CPU clocks can be changed by using the low-order two bits of PCC and the least significant bit of SCC. However, this clock change is not immediatly made after the register are rewritten, and the clock before the clock change is made is used for operation during given machine cycles. Thus, to stop main system clock oscillation, a STOP instruction must be executed or SCC.3 must be set after the change time elapses. Table 5.2-1 Maximum Time Required to Change System and CPU Clocks | | etup val<br>ore cha | | | Setup value after change | | | | | | | | | | | |-----|---------------------|-----|-------------------|--------------------------|-------------------|-----------------|------|------|----------------------------------------------------|---------------------------------------------------|------|-----------|------|------| | SCC | PCC | PCC | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | .1 | | | 0 | 0 | | | | 1 machine cycle | | | 1 machine cycle | | | Inhibited | | | | 0 | 1 | 0 | 8 machine cycles | | | | | | 8 machine cycles | | | Inhibited | | | | | 1 | 1 | 16 machine cycles | | 16 machine cycles | | | | | f <sub>X</sub> machine cycles (32 machine cycles) | | | | | | 1 | 1 | 1 | Inhibited | | . '. | Inhibited | | | f <sub>X</sub> machine cycles (32 machine cycles) | | | | | | The values enclosed in parentheses are applied when $f_x = 4.19$ MHz and $f_{xT} = 32.768$ kHz. Remarks: The CPU clock $\Phi$ is supplied to the $\mu$ PD75268 internal CPU. The reciprocal of the clock becomes the minimum instruction time. (The present manual defines it to be one machine cycle.) (2) System and CPU clock change sequence System and CPU clock change is explained using Fig. 5.2–6. 1) When the RESET signal is generated, the CPU starts operating at the minimum speed of the main system clock (15.3 µs / 4.19 MHz) after the wait time (31.3 ms / 4.19 MHz) to allow time for stabilizing the oscillator. - After enough time has elapsed for the V<sub>DD</sub> pin voltage to rise to an adequate level PCC is rewritten and the μPD75268 operates at the maximum speed. - 3) Turning off the commercial power supply is detected by using interrupt input (INT4 is useful); SCC. 0 is set, and the µPD75268 operates using the subsystem clock. (At the time, a check must have been made to ensure that subsystem clock oscillation has started. After the time required to change to the subsystem clock (32 machine cycles) has elapsed, SCC 3 is set and main system clock oscillation is stopped. - 4) Restoration of the commercial power supply is detected by using an interrupt. SCC. 3 is cleared and main system clock oscillation is started. After the time required to stabilize oscillation has elapsed, SCC. 0 is cleared and the μPD75268 operates at the maximum speed. #### 5.3 Basic Interval Timer #### 5.3.1 Basic interval timer configuration Fig. 5.3-1 shows the configuration of the basic interval timer Remarks: \* denotes instruction executing. MOV Figure 5.3-1 Basic Interval Timer Configuration ### 5.3.2. Basic interval timer mode register (BTM) BTM, A BTM is a 4-bit register for controlling operation of the basic interval timer. BTM is set by using a 4-bit memory operation instruction. Bit 3 can be set individually by using a bit operation instruction. Example 1: To set the interrupt generation interval to 1.95 ms (4.19 MHz). ; BTM- 1111B SEL MB15 ; or CLR1 MBE MOV A, # 1111B Example 2: To clear BT and IRQBT (watchdog timer application). SEL MB15 ; or CLR1 MBE SET1 BTM.3 ; BTM BIT 3 is set to 1. When bit 3 is set to 1, the basic interval timer contents are cleared. At the same time, the basic interval interrupt request flag (IRQBT) is also cleared. (The basic interval timer starts.) When the RESET signal is generated, the BTM contents are cleared and interrupt request signal generation is set for the longest interval. Fig. 5.3-2 Basic Interval Timer Mode Register Format ## 5.3.3. Basic interval timer operation The basic interval timer (BT) is incremented each time a pulse is received from the clock generator. When an overflow occurs, the interrupt request flag (IRQQBT) is set. BT count operation cannot be stopped. An interrupt generation time interval can be selected from among four types by setting BTM. (See Fig. 5.3—2.) The basic interval timer and interrupt request flag can be cleared by setting BTM bit 3 to 1 (the interval timer function starts). The basic interval timer (BT) count can be read by using an 8-bit operation instruction. Data cannot be written into BT. #### Caution: To prevent reading of unstable data during count update when reading the basic interval timer count, execute the read instruction twice and compare the results. If they are valid values, the later read value is used as the read result, if they differ from each other completely, reexecute from the beginning. Example: To read the BT count SET1 MBE SEL MB15 BT address is set in HL. MOV HL. #BT XA, @HL LOOP: MOV First read MOV BC, XA XA, @ HL MOV Second read SKE A. C BR LOOP MOV A, X SKE A, B BR LOOP The wait function is provided to stop CPU operation until the basic interval timer overflows in order to allow time for system clock oscillation to become stable when the STOP mode is released. Although the wait time after the RESET signal is generated is fixed, it can be selected by setting BTM when the STOP mode is released by an interrupt. The wait time is selected by setting BTM as shown in Fig. 5.3-2. BTM setting must be performed before the STOP mode is set. ### 5.3.4 Basic interval timer application examples Example 1: To enable basic interval timer interrupt and set interrupt generation interval at 1.95 ms (at 4.19 MHz). SEL MB 15 MOV A, #1111B MOV BTM, A ; BTM setting and timer function start EI IEBT ; Interrupt is enabled.: BT interrupt is enabled. Example 2: Watchdog timer application A program is divided into several modules which terminate processing within the BT setup time. BT and IRQBT are cleared at the end of each module. If an interrupt is generated, overrun is assumed to have occured. SEL MB15 Initial- MO MOV A, #1101B ; MOV BTM. A : ; 7.8 ms interval is set. EI V BTM, A BTM setting and timer function start ΕI EI IEBT Example 3: To set the wait time, when the STOP mode is released, using an interrupt to 7.8 ms. SEL MB15 ; or CLR1 MBE MOV A, #1101B MOV BTM, A ; BTM ← 1101B MOV BTM, A STOP STOP mode is set NOP ### Example 4: To set the high-level width of a pulse input to INT4 interupt (both rising and falling edge detection). (The pulse width must not exceed the BT setup value. The BT setup value must be 7.8 ms or more.) < INT4 interrupt routine (MBE = 0) > ``` LOOP: MOV XA, BT First read MOV BC, XA Data is stored. MOV XA, BT Second read SKE A. C BR LOOP MOV A, X SKE A, B BR LOOP SKT PORT0.0 P00=1? BR NO AA MOV XA. BC Data is stored in data memory. MOV BUFF, XA CLR1 FLAG RETI AA: MOV HL, #BUFF MOV A, C SUBC A, @HL INCS 1 MOV C, A A, X MOV SUBC A. @HL MOV B, A XA, BC MOV MOV BUFF, XA Data is stored. SET1 FLAG Data existence flag is set. RETI ``` ### 5.4 Watch Timer The $\mu PD75268$ incorporates a watch timer (one channel) which has the following function: - (a) The test flag (IRQW) is set at 0.5 s time intervales. The standby mode can be released using IRQW. - (b) The main system and subsystem clocks can be assigned 0.5-s intervals. - (c) In the rapid feed mode, time intervals multiplied by 128 (3.91 ms) are enabled. The mode is useful for program debugging and testing. - (d) A fixed frequency (2.048 kHz) can be output to P23/BUZ. It can be used for sounding the buzzer and trimming the system clock oscillation frequency. - (e) Since the scaler can be cleared, the watch can be started at zero seconds. ### 5.4.1 Watch timer configuration Fig. 5.4-1 shows a watch timer block diagram. The values enclosed in parentheses are applied when $f_x = 4.194304$ MHz and $f_{xT} = 32.768$ kHz. Figure 5.4-1 Watch Timer Block Diagram # 5.4.2 Watch mode register The watch dog timer (WM) consists of eight bits to control the watch timer. Fig. 5.4–2 shows the watch mode register format. The watch mode register is set using an 8-bit operation instruction. When the RESET signal is generated, all bits are cleared. Example: To produce time using the main system clock (4.19 MHz). To enable buzzer output. CLR1 MBE MOV XA, #84H MOV WM, XA ; WM set Address | ddress | | | | | | | | | Symbol | |--------|-----|---|---|---|---|-----|-----|-----|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | F98H | WM7 | 0 | 0 | 0 | 0 | WM2 | WM1 | WM0 | WM | Count clock (fw) selection bit | | WMO | 0 | System clock dividing output $\frac{f_X}{128}$ is selected. | |---|--------|---|-------------------------------------------------------------| | ١ | ****** | 1 | Subsystem clock f <sub>XT</sub> is selected. | Operation mode selection bit | WM1 | 1 1 | Normal watch mode (IRQW is set by using $\frac{f_W}{2^{14}}$ , 0.5 s) | |-------|-----|------------------------------------------------------------------------| | VVIVI | 1 | Rapid feed watch mode (IRQW is set by using $\frac{f_W}{2}$ , 3.91 ms) | Watch operation enable/disable bit | WM2 | 0 | Watch operation is stopped (divider is cleared). | |--------|---|--------------------------------------------------| | VVIVIZ | 1 | Watch operation is enabled. | BUZ output enable/disable bit | WM7 | 0 | BUZ output is disabled. | |--------|---|-------------------------| | ****** | 1 | BUZ output is enabled. | Figure 5.4-2 Watch Mode Register Format # 5.5 Timer/event counter configuration The $\mu PD75268$ incorporates a timer/event counter (one channel) as shown in Fig. 5.5–1. The timer/event counter functions are as follows: - (a) Programmable interval timer operation - (b) Event counter operation(c) Count read function Remarks: \*denotes instruction executing Fig. 5.5-1 Timer/event Counter Block Diagram #### 5.5.2 Basic configuration and operation of timer/event counter The timer/event counter operation mode can be selected by using the timer/event counter mode register (TM0). The basic configuration and operation of the timer/event counter are explained below: - (1) Count pulse CP is selected by setting TM0 and input to the 8-bit count register T0. - (2) To is a binary 8-bit up counter incremented by one when CP is input. It is cleared when the RESET signal is generated, TM0 bit 3 is set (timer start), or coincidence signal is generated. To can be read at any time using an 8-bit memory operation instruction, but cannot be written - (3) The modulo register TMOD0 consists of eight bits to determine the T0 count. A value is set in TMOD0 using an 8-bit memory operation instruction, but TMOD0 cannot be read. When the RESET signal is generated, TMOD0 is initialized to FFH - (4) The comparator compares the T0 and TMOD0 contents. If they match, it generates a coincidence signal and sets the interrupt request flag (IRQT0) - Fig. 5.5-2 shows the count operation timing. Figure 5.5-2 Count Operation Timing Chart ### 5.5.3 Timer/event counter mode register (TM0) The mode register (TM0) consists of eight bits to control the timer/event counter. Fig. 5.5–3 shows the timer/event counter mode register format. The timer mode register is set by using an 8-bit memory operation instruction. Bit 3 is a timer start bit which can be set individually. Bit 3 is reset to 0 automatically when timer operation starts. Example 1: To start the timer in interval timer mode with CP = 4.09 kHz. SEL MB15 ; or CLR1 MBE MOV XA, #01001100B ; MOV TM0,XA ; TM0 ← 4CH Example 2: To restart the timer according to how the timer mode register is set. SEL MB15 ; or CLR1 MBE SET1 TM0.3 : TM0.BIT3 ─ 1 When the RESET signal is generated, all the timer mode register bits are cleared. Remarks: The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. Figure 5.5-3 Timer/Event Counter Mode Register Format #### 5.5.4 Timer/event counter operation mode The timer/event counter operates in the count operation stop or count operation mode depending on how the mode register is set. The following are always enabled independently of how the mode register is set - 1) TI0 pin signal input and test. (P13 pin input test can be made.) - 2) Modulo register (TMOD0) setting. - 3) Count register (T0) read. - (a) Count operation stop mode The count operation stop mode is set when TM0 bit 2 is set to 0. Since count pulse (CP) supply to the count register is stopped, count operation is not performed (b) Count operation mode The count operation mode is set when TM0 bit 2 is set to 1. Count pulses selected by using bits 4 to 6 are supplied to the count register, and count operation is performed as shown in Fig. 5.5–2. Normally, timer operation is started by - 1) setting a count value in the modulo register (TMOD0), then - 2) setting the operation mode, count clock, and start indication in the mode register (TM0). The modulo register is set by using an 8-bit data transfer instruction. Caution: Set a value other than 0 in the modulo register. Example: To set 3FH in channel 0 modulo register. SEL MB15 ; or CLR1 MBE MOV XA, #3FH MOV TMODO, XA # 5.5.5 Timer/event counter time setting "Timer setup value" (period) is equal to "modulo register contents + 1" divided by "count pulse frequency" selected by setting the timer mode register. $$T(s) = \frac{n+1}{F_{CP}}$$ T (s) : Timer setup value (seconds) F<sub>CP</sub> (Hz) : Count pulse frequency (Hz) n : Modulo register value (n ≠ 0) Once the timer is set, an interrupt request signal (IRQT0) is generated at the setup time intervals. Table 5.5–1 lists the resolution and maximum setup value (time when FFH is set in the modulo register) of the timer/event counter for each count pulse. Example: To produce 30 ms time intervals. ( $f_x = 4.194304 \text{ MHz}$ ) Use the mode with the maximum setup time 62.5 ms. $$\frac{30 \text{ ms}}{244 \text{ }\mu\text{s}} = 122.9 = 7\text{AH}$$ Set 79H in the modulo register. SEL MB15 MOV XA, #79H MOV TMOD0. XA # Table 5.5-1 Resolution and Maximum Setup Value (4.19 MHz) | М | ode regist | er | Timer cl | nannel 0 | |------|------------|------|------------|--------------------| | TMO6 | TMO5 | TMO4 | Resolution | Maximum setup time | | 1 | 0 | 0 | 244 μs | 62.5 ms | | 1 | 1 . | . 0 | 15.3 μs | 3.91 ms | #### 5.5.6 Caution on timer/event counter application # (1) Error at timer start An error with a maximum length of one clock period of the count pulse (CP) for the value calculated in 5.5.5 occurs in the time until a coincidence signal is generated after the timer starts (TM0.3 is set). This is because clearing of the count register is not synchronized with CP as shown in Fig. 5.5-6. Figure 5.5-6 Error at Timer Starting #### (2) Caution at timer start Normally, the count register T0 and interrupt request flag IRQT0 are cleared when the timer starts (TM0 bit 3 is set). However, if the timer is placed in the operation mode, and IRQT0 setting and timer start occur simultaneously, IRQT0 may be unable to clear. There is no problem when IRQT0 is used for a vectored interrupt. In IRQT0 test application, however, a problem arises such than IRQT0 is set although the timer has been started. Thus, to start the timer at IRQT0 timing, stop the timer once (by setting TM0 bit 2 to 0), then restart it, or start the timer twice. Example: Timer start at IRQT0 timing may be set TM0.3 SEL MB15 or CLR1 MBE MOV XA. #0 MOV TM0. XA Timer stop MOV XA. #4CH MOV TM0, XA Restart SEL MB15 or CLR1 MBE SFT1 TM0.3 Restart # SET1 (3) Error at count register read or The count register contents can be read at any time using an 8-bit data memory operation instruction. During execution of the instruction, count pulse change is held and count register change is suppressed. Thus, if the count pulse signal source is input to TIO, count pulses as long as the instruction execution time are deleted. (This symptom does not occur if the internal clock is used for count pulses because they are synchronized with the instruction.) Therefore, if TIO is input as a count pulse and the count register contents are read, signals having a pulse width that prevents miscount, even if count pulses are deleted, must be input. Since the count hold period in read instruction execution is one machine cycle, the pulse width input to the TIO pin must be longer than one machine cycle. # (4) Caution at count pulse change If the timer mode register is rewritten and count pulse change is made, its specification becomes effective immediately after instruction execution. A count pulse (1) or 2 in the timing chart shown below) may occur depending on the clock combination when the count pulse changed. In this case, a miscount may occur or the count register contents may be destroyed. To change count pulse, be sure to set count mode register bit 3 to 1 and restart the timer at the same time. # (5) Operation after modulo register change The modulo register is changed when an 8-bit data memory operation instruction is executed. If the value appearing after the modulo register is changed and becomes smaller than the count register value, the count register continues counting and overflows, then restarts counting from 0. Thus, if the value after the modulo register is changed (m) and becomes smaller than the value before it was changed (n), the timer must be restarted after the modulo register is changed. ## 5.5.7 Timer/event counter application (1) Timer 0 is applied to an interval timer generating an interrupt at 50 ms intervals. — The high-order four bits of the mode register are set to 0100B and a maximum setup time of 62.5 ms is selected. - The low-order four bits of the mode register are set to 1100B. - The modulo register setup value is as follows: $$\frac{50 \text{ ms}}{244 \text{ }\mu\text{s}} = 205 = \text{CDH}$$ Example: SEL ; or CLR1 MBE SEL MB15 MOV XA. #0CCH MOV XA, #UCCH MOV TMOD0, XA ; Modulo is set. MOV XA, #01001100B MOV TM0. XA MOV TM0, XA ; Mode is set and timer is started. El ; Interrupts is enabled. EI IETO ; Timer interrupt is enabled. Remarks: In this application, the TIO pin can be used as an input pin. #### 5.6 Serial Interface The μPD75268 contains a clocked 8-bit serial interface. The serial interface has the following functions. - (1) 8-bit send and receive operation synchronized with the clock (simulataneous send and receive operations) - (2) 8-bit serial bus operation synchronized with the clock (the S0 pin is used for data I/O, and the format of S0 output is N-ch open drain output.) - (3) Half-duplex start-stop transfer (controlled by sofware) - (4) Selection from four clock sources - (5) LSB/MSB inversion function for starting transfer This serial interface facilitates data transfer with other microcomputers including the $\mu PD7500$ series and connection with peripheral devices. ## 5.6.1 Configuration and operation of serial interface. Figure 5.6-1 shows the configuration of the serial interface. The operation mode and transfer clock of the serial interface are controlled with the serial operation mode register (SIOM). The basic configuration and operation of the interface are described below. - (1) The setting of the SIOM selects a transfer clock used as the shift clock (SCK) supplied to the 8-bit shift register (SIO). - (2) The SIO is a shift register that performs a shift operation in phase with an edge of SCK. An 8-bit data memory manipulation instruction is used to write to or read from the SIO. The SIOM can be set so that an SIO read or write operation can be performed starting with the LSB or MSB as desired. This function can select whether data transfer operation is to be started from the LSB or MSB. - (3) The serial clock counter is a 3-bit up-counter, incremented on the rising edge of SCK. When this counter overflows, it sets the interrupts request flag IRQSIO, disables the supply of SCK to the SIO, and stops serial transfer operation. - (4) During serial transfer, SIOM.4 can be used to set the SO output state. \*. Instruction execution 1: Output buffer that can be switched between COMS, or N-ch open drain. Fig. 5.6-1 Serial Interface Block Diagram 5.6.2 Serial operation mode register (SIOM) The serial operation mode register is an 8-bit register for specifying a serial interface operation mode. (See Figure 5.6-2) An 8-bit memory manipulation instruction is used to set the serial operation mode register. Bit 3 can be set to 1 independently of the other bits by using the instruction SET1 SIOM.3 (serial interface start instruction) to clear the serial clock counter and interrupt request flag (IRQSIO) and start serial interface transfer operation. Example 1: Serial clock $\phi$ is selected, and serial send and receive operations are started from the MSB. SEL MB15 ; Or CLR1 MBE MOV XA,#01001110B MOV SIOM, XA ; SIOM ← 01001110B Example 2: Serial transfer operation is started according to the setting of the SIOM. SEL MB15 ; Or CLR1 MBE SET1 SIOM.3 When the serial interface starts operation, bit 3 is automatically reset to 0. A RESET signal occurrence clears all bits to 0, except for Bit 4. Bit 4 is set to 1 after RESET. Address FE0H 7 6 5 4 3 2 1 0 Symbol SIOM7 SIOM6 SIOM5 SIOM4 SIOM3 SIOM2 SIOM1 SIOM0 SIOM SIOM ### Shift Register Read/Write Bit Sequency Specification Bit | SIOM 0 | 0 | SIO <sub>7</sub> to SIO <sub>0</sub> XA (MSB first se | erial transfer) | | 8.5 | |--------|---|-------------------------------------------------------|-----------------|--|-----| | | 1 | SIO <sub>0</sub> to SIO <sub>7</sub> XA (LSB first se | rial transfer) | | | ## Serial Interface Operation Mode Selection Bit | | | Operation Mode | SO Pin Output Buffer Format | Serial Data Input Pin | | |-------|---|-------------------|-----------------------------|-----------------------|--| | SIOM1 | 0 | Serial bus mode | N-ch open drain | P02-SO | | | | 1 | Send/receive mode | CMOS output | P03/SI | | # Serial Interface Operation Enable/Disable Bit | | | Shift Register Operation | ft Register Operation Serial Clock Counter | | |-------|---|--------------------------|--------------------------------------------|----------| | SIOM2 | 0 | Shift stop | Operation stop (hold) | Hold | | | 1 | Shift operation | Count operation | Settable | ### Serial Interface Start Instruction Bit | SIOM3 | Serial transfer is started by written "1". Automatically reset (0) after transfer starts. | | |-------|-------------------------------------------------------------------------------------------|--| #### Output Data to SO Output Latch | SIOM4 | 0 | Output 0 to SO output latch | | |-------|---|-----------------------------|--| | | 1 | Output 1 to SO output latch | | ### Serial Clock Selection Bits | SIOM7 | SIOM6 | SIOM5 | Serial Clock | |-------|-------|-------|---------------------------------------------| | 0 | 0 | 0 | SCK pin input external clock | | 0 | 0 | 1 | Reserved | | 0 | 1 | Х | φ* (1.05 MHz, 524 kHz, 65.5 kHz) | | 1 | 0 | 0 | f <sub>xx</sub> /2 <sup>10</sup> (4.09 kHz) | | 1 | 0 | 1 | Reserved | | 1 | 1 | 0 | | | 1 | 1 | 1 | f <sub>XX</sub> /2 <sup>4</sup> (262 kHz) | Values in ( ) are for $f_{XX} = 4.19$ MHz. X: Don't care Fig. 5.6-2 Serial Operation Mode Register Format ### 5.6.3 Serial interface operation Serial interface has the following operation modes: - Operation stop mode - · Serial operation mode - (i) Operation stop mode When SIOM bit 2 is "0", the serial interface is set to the operation stop mode. In this mode, serial transfer is not performed. The serial interface is set to this mode when reducing the power consumption by not using the serial interface. Since the shift operation is not performed in this mode, the shift register can be used as a normal 8-bit register. In this mode, the status of the SO output latch can be set by SIOM.4 specification. Thus the SO pin can be used as normal static output. The RES signal sets the serial interface to this mode. (ii) Serial operation mode When SIOM bit 2 is "1", the serial interface is set to the serial operation mode. There are two serial operation modes, depending on the contents of SIOM bit 1: - ① Serial send/receive mode (SIOM1 = 1) - ② Serial bus mode (SIOM1 = 0) Their operation timing is shown in Figure 5.6-3 and Figure 5.6-4, respectively. Note: DI Serial Data Input DO Serial Data Output Fig. 5.6-3 Serial Send/Receive Mode Timing Fig. 5.6-4 Serial Bus Mode Timing In the <u>serial</u> send/receive mode, the receive data is placed in the shift register from the SI pin in synchronization with the serial clock (<u>SCK</u>) and at the same time, the send data is output from the SO terminal. At this time, the SO outp<u>ut becomes CMOS output.</u> In the serial bus mode, the contents of the shift register are output to the SO pin in synchronization with SCK and at the same time, the data of the same SO pin is fetched to the shift register. At this time, the SO output becomes N-ch open drain output. In serial bus mode use, transfer is divided into transfer when serial data is output and transfer when serial data is input. When serial data is output, the send data is written to the shift register the same as in the serial send/receive mode. When serial data is input the serial bus is opened by turning off an N-ch transistor by written FFH to the shift register beforehand. In the serial bus mode, the P03/SI pin can be used as general-purpose input. Four kinds of clocks can be selected as the serial clock by mode register setting as shown in Table 5.6-1. Shift operation is normally started by: - ① Loading the transfer data into the shift register (SIO) - © Setting the operation mode, serial clock selection, and start order in the serial interface operation mode register (SIOM). Serial transfer stops automatically and the interrupt request flag (IRQSIO) is set at the end of transfer of 8 bits. While serial transfer is stopped, the status of the SO output latch can be set by SIOM.4 specification. Table 5.6-1 Serial Clock Selection and Applications | Mode register | | Serial clock | | Timing wich enables R/W of shift register and start of data transfer | Andination | | | |---------------|-----------|--------------|----------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------|--| | SIOM<br>7 | SIOM<br>6 | SIOM<br>5 | Source | Masking of serial clock | register and start of data transfer | Application | | | 0 | 0 | 0 | External<br>SCK | Automatically<br>masked at end<br>of 8-bit data<br>transfer. | Enable only while serial transfer is stopped, * or while SCK is at high level. | Slave CPU | | | 0 | 1 | Х | ф | | Enabled at any time | High-speed serial transfer | | | 1 | 0 | 0 | f <sub>xx</sub> /2 <sup>10</sup> | | Enabled only while serial transfer is stopped,* or while SCK is at high level. | Low-speed serial transfer | | | 1 | 1 | 1 | f <sub>XX</sub> /2 <sup>4</sup> | | ingirievei. | Middle-speed serial transfer | | <sup>\* &</sup>quot;While serial transfer is stopped" means a condition in which the serial clock is masked after an 8-bit data transfer of during operation stop mode. Note: In case that CPU is set in the lowest speed mode (PCC=0000), medium speed mode for serial clock (SiOM=111xxxxx) may not be used. The shift register is read and written by 8-bit transfer instruction. At this time, the shift register can be read and written by reversing the LSB and MSB by SIOM bit 0 specification. Transfer can be switched between LSB first and MSB first with this function. Example: Transfer the data of the RAM specified by the HL register pair to SIO and at the same time, fetch the SIO data to the accumulator. MOV XA, @HL ; take send data from RAM. SEL MB15 ; or CLR1 MBE XCH XA, SIO ; swap send data and receive data The serial transfer timing when $\phi$ was selected as the serial clock is shown in Figure 5.6-5. (The transfer data can be read and written by waiting 7 machine cycles.) Fig. 5.6-5 Transfer Timing when $\phi$ is selected as Serial Clock ### 5.6.4 Serial interface applications The serial interface function are usually programmed in applications as follows: - Sets transfer data into the shift register (SIO). - Sets the operation mode, serial clock type, and start specification on the mode register (SIOM). - After testing interrupt routine or interrupt request flag (IRQSIO), reads received data. - (1) Transfers data in MSB-first at a transfer clock rate of 262 kHz (at 4.19 MHz) (master option): Example: CLR1 MBE MOV XA, TDATA : TDATA is the address where transfer data is stored. MOV SIO, XA ; Sets transfer data MOV XA, #11101110B MOV SIOM, XA ; Starts transfer Note: The second and all the subsequent data transfer can be started with SET1 SIOM.3. In this application the SI/P03 pin of the µPD75268 can be used as an input. (2) Sends and receives data in MSB-first at a clock rate of 4.09 kHz (at 4.19 MHz) (master option): This application uses a low transfer clock rate and is suitable for interfacing with a microprocessor having no serial interface such as the $\mu$ PD7556. Exampe: Main routine CLR<sub>1</sub> MBE MOV XA, TDATA MOV SIO, XA XA, #10001110B MOV MOV SIOM, XA ΕI ; Starts transfer ; Sets transfer data ΕI **IESIO** ; Enable SIO interrupt 2nd and subsequent transfer start MBE CLR<sub>1</sub> MOV XA, TDATA SIO. XA MOV SET1 SIOM.3 Interrupt routine (MBE=0) MOV XA, SIO MOV RDATA, XA RETI ; Save received data. RDATA is address where received data is stored. (3) Send and receives data in LSB-first using an external clock (slave operation). (In this application, the shift register is accessed by using the LSB-first/MSB-first selectable function.) Example: Main routine CLR<sub>1</sub> MBE MOV XA, #01H MOV SIOM, XA MOV XA, TDATA ; Stops serial transfer and enters LSB-first mode. MOV SIO, XA MOV XA, #0FH MOV SIOM, XA : Sets transfer data : External clock ; Starts transfer ΕI ΕI **IESIO** ; Enables SIO interrupt Interrupt routine (MBE=0) MOV XA, TDATA XCH XA. SIO MOV RDATA, XA ; Receive data -- send data ; Saves received data SET1 SIOM.3 RETI (4) Configures a serial bus and connects more than one device to it Example: Configures a system in which the μPD75268 function as a master device and μPD75104, μPD7519H, and μPD7225G function as slave devices connected via a serial bus: In this bus configuration, SI and SO pins are connected, and the SO pins should be set to high impedance to release the bus except when the SO is outputting serial data. Since the $\mu$ PD7519H cannot put the SO pin to high-impedance state, the $\mu$ PD7519H should be provided with an open-collector transistor as shown in the figure above. Data 00H should be written into the shift register so that the transistor can be turned off at data input timing. The timing when each microprocessor outputs data should be determined. The master processor $\mu$ PD75268 delivers a serial clock and all other slave processors operate on that clock (external clock). (5) Use the CPU clock φ (0.95 μs at 4.19 MHz) for the transfer data at high speed: Programming example ---- Master device CLR<sub>1</sub> MOV XA, TDATA MOV : Sets transfer data. SIO, XA XA, #01001110B MOV MOV SIOM, XA ; Starts transfer. 7 machine cycle XA, SIO ; Fetches received data #### 5.7 FIP Controller/Driver #### 5.7.1 FIP controller/driver configuration and operation The $\mu$ PD75268 contains a display controller which reads the display data memory contents by DMA operation and automatically generates digit and segment signals. The high-voltage output buffer for the FIP controller/driver can directly drive a fluorescent indicator panel (FIP). Figure 5.7-1 shows the FIP controller/driver configuration. Fig. 5.7-1 FIP Controller/Driver Block Diagram The Function of the $\mu PD75268$ internal FIP controller/Driver are as follows: - (i) Display data memory is read automatically by DMA operation, and segment and digit signals are generated. - (ii) A maximum of 26 display elements can be selected as desired in the range of nine to 16 segments and nine to 16 digits. - (iii) The remaining display output can be used for static output. - (iv) The intensity can be adjusted in eight stages by using the dimmer function. - (v) Key scan application is enabled. - · Interrupt generation at key scan timing (IRQKS) - · Key scan data can be output from the segment output pins. - (vi) High voltage (40 V) output pins for directly driving the FIP Segment-only pins (SO-S9): V<sub>OD</sub> = 40 V, I<sub>OD</sub> = 3 mA Digit output pins (TO-T15): V<sub>OD</sub> = 40 V, I<sub>OD</sub> = 15 mA (vii) An internal pull-down resistor can be including for each bit by mask option. The FIP controller reads data stored in display data memory in sequency and outputs it to the segment pin (S<sub>N</sub>). Fig. 5.7-2 shows the timing for the FIP controller. The display mode is determined by a combination of the digit signal assigned the number of digits specified in the digit select register (DIGS) and the segment signal assigned the number of segments specified in the display mode register (DSPM). For display leakage glare, prevention or intensity adjustment (dimmer), a digit signal whose cut width is specified in the dimmer select register (DIMS) is output. The key scan registers (KS0 and KS1) are mapped in the display data memory. Data set in KS0 and KS1 is output from the segment output pins at the key scan timing. Digit select register setup value $$T_{DSP}: \ \ \ One \ display \ cycle - \frac{1024}{f_{\chi\chi}}: 244 \ \mu s \ at \ 4.19 \ MHz, - \frac{2048}{f_{\chi\chi}}: 488 \ \mu s \ at \ 4.19 \ MHz)$$ $$T_{CYT}: \ \ Display \ period \ (T_{CYT} = T_{DSP} \times \ (N+2))$$ T<sub>DIG</sub>: Digit signal pulse width which can be changed in eight stages by using the dimmer select register. ### Fig. 5.7-2 FIP Controller Operation Timing - 1. The FIP controller/driver can operate only with high speed or medium speed (PCC = 0011B or 0010B) main system clock (SCC.0 = 0). In another clock mode or in standby mode, be sure to stop FIP controller operation (DSPM.3 = 0), or else the FIP controller may malfunction. - 2. PORTH, when used for the digit/segment signals (T10/S15-T13/S12), is either placed in high impedance (when no pull-down resistor is contained) or goes low (when internal pull-down register is contained) in display off mode, etc. Thus, PORTH should be turned off when display is turned off in standby mode, etc. # 5.7.2 Display mode selection The number of segments and digits that can be displayed by the internal FIP controller/driver is determined by selecting the display mode. Remark 1: Pins not used for display can be used for an output port. Fig. 5.7-3 Display Mode Selection # 5.7.3 FIP controller/driver registers (1) Display mode register (DSPM) is a 4-bit register used to specify whether display operation is enabled or disabled and the number of display segments. Fig. 5.7-4 shows the DSPM register format. The display mode register is set by using a 4-bit memory handling instruction. When the Standby mode (STOP or HALT) is set or the FIP controller/driver is operated on the subsystem clock ( $f_{XT}$ ), preset DSPM.3 to 0 to stop display operation. When the RES signal is generated, all the DSPM bits are cleared. Example: To use 11-segment display SEL MB15 MOV A, #1010B MOV DSPM, A Specification bit for the number of display segments | DSPM2* | DSPM1 | DSPM0 | Number of display segments | |--------|-------|-------|----------------------------| | 0 | 0 | 0 | 9 segments | | 0 | 0 | 1 | 10 segments | | 0 | -1 | 0 | 11segments | | 0 | 1 | 1 | 12 segments | | 1 | 0 | 0 | 13 segments | | 1 | 0 | 1 | 14 segments | | 1 | 1 | 0 | 15 segments | | 1 | 1 | 1 | 16 segments | Specification as to whether display operation is enabled or displayed | DSPM3 | 0 | Display stop | | |-------|---|-----------------|--| | | 1 | Display enabled | | Fig. 5.7-4 Display Mode Register Format # (2) Digit select register (DIGS) The digit select register (DIGS) is a 4-bit register used to specify the number of display digits. Fig. 5.7-5 shows the DIGS register format. DIGS is set by using a 4-bit memory handling instruction. The number of display digits can be selected within the range of nine to 16 by setting DIGS. A value less than nine cannot be selected. When the RES signal is generated, DIGS is set to 1000B, selecting a 9-digit display. Example: To select a 10-digit display. SEL MB15 MOV A, #9 MOV DIGS, A | DIGS-DIGS3 setup value | Number of display digits | |------------------------|--------------------------| | N | N+1 | | N = 8 - 15 | | Fig. 5.7-5 Digit Select Register Format #### (3) Dimmer select register (DIMS) The dimmer select register (DIMS) is a 4-bit register used to specify the digit signal cut width for display leakage glare prevention or intensity adjustment (dimmer function). It is also used to select the display cycle $(T_{DSP})$ . Fig. 5.7-6 shows the DIMS format. Fig. 5.7-7 shows the waveform of the digit signal for each setup value. DIMS is set by using a 4-bit memory handling instruction. Normally, $488 \,\mu s$ at $4.19 \,MHz$ is selected for the display cycle by setting DIMS.0 to 1 lessen leakage glare. However, as the number of display digits increases, the display cycle approaches the commercial supply power frequency and the display flickers; $244 \,\mu s$ at $4.19 \,MHz$ is selected. When RES signal is generated, all the DIMS bits are cleared. Caution: To avoid display flickering be shure to change the DIMS register in display off phase or in key scan interrupt routine. Example: To select a cut width of 1/16 and a display cycle of 488 µs. SEL MB15 MOV A, #1 MOV DIMS, A #### Address | 20.000 | 3 | 2 | 1 | 0 | | |--------|-------|-------|-------|-------|------| | F89H | DIMS3 | DIMS2 | DIMS1 | DIMS0 | DIMS | #### Display cyle specification bit | DIMS0 | 0 | 1024 = one display cycle. (one cycle = 244 μs at 4.19 MHz) | |-------|---|----------------------------------------------------------------------------------| | | 1 | $\frac{2048}{f_{XX}}$ = one display cycle. (one cycle = 488 $\mu$ s at 4.19 MHz) | # Specification bit for the number of display segments | DIMS3 | DIMS2 | DIMS1 | Digit signal cut width | |-------|-------|-------|------------------------| | 0 | 0 | 0 | 1/16 | | 0 | 0 | 1 | 2/16 | | 0 | 1 | 0 | 4/16 | | 0 | 1 | 1 | 6/16 | | 1 | 0 | 0 | 8/16 | | 1 | 0 | 1 | 10/16 | | 1 | 1 | 0 | 12/16 | | 1 | 1 | 1 | 14/16 | Fig. 5.7-6 Dimmer Select Register Format Note: 1-display timing is $2048/f_{yy}$ (with DIMS0 = 1) = $488 \mu s/4.19$ MHz or $1024/f_{yy}$ (DIMS0 = 0) = $244 \mu s/4.19$ MHz. Fig. 5.7-7 Digit Signal Waveform ### 5.7.4 Display data memory The display data memory is the area of data memory used by the display controller to write segment output data read by DMA operation. The area not used for display can be used for normal data memory. The display data memory is mapped in data memory addresses 1COH-1FFH. Display data memory addresses 1FCH, 1FDH, 1FEH and 1FFH are also used for the key scan registers (KS0 and KS1). The display data memory can be handled in 1-, 4-, or 8-bit units by using data memory handling instructions. Fig. 5.7-9 shows an example how display data memory is related to the segment output. The shaded area in the figure is an example of how the data memory is used when the 14-segment mode is selected (14-segment 10-digit display). In this example, the S0-S9, T13/S12/PH0-T10/S15/PH3 and T0-T9 pins are used for display, and the T14/S11 and T15/S10 pins can be used for static output. In this case, KS1 bits 2 and 3 (high-order two bits of address 1FEH) are output to the T14/S11 and T15/S10 pins. (However, note that T14/S11 and T15/S10 pin output changes after a maximum delay of one display cycle after KS1 data is rewritten.) | | | 1C3H + 4n | 1C2H + 4n | 1C1H + 4n | 1C0H + 4n | |----------------|-------|-----------|-----------|-----------|-----------| | Number of bits | 1 bit | 0 | 0 | 0 | 0 | | that can be | 4 bit | 0 | 0 | 0 | 0 | | manipulated | 8 bit | Ō | | 0 | | Fig. 5.7-8 Number Display Data Memory Bits that can be Manipulation (n = 0 - 15) The shaded portion denotes the area used when 14-segment mode is selected. (14-segment 10-digit display)) Fig. 5.7-9 Example of Relationship between Display Data Memory and Segment Output (Example μPD75268) ## 5.7.5 Key scan registers and flag (1) Key scan registers (KS0 and KS1) The Key scan registers (KS0 and KS1) are mapped in part of the display data memory (addresses 1FCH-1FFH) and are used to set segment output data at the key scan interval. KS0 and KS1 are 8-bit registers which normally are operated by 8-bit manipulation instructions. (They can also be manipulated in 1- or 4-bit units.) Data in KS0 and KS1 is output from the segment output pins at the key scan interval. If KS0 and KS1 are rewritten during the key scan interval, segment output data can be changed immediately. The segment output can be used for key scanning. KS1 also serves as an output data register when any remaining display output pins are used for static output. In this case, KS1 high-order 3-bit data corresponds to the S9-S11 pins. Static data output from the S9-S11 pins can be changed immediately when KS1 is rewritten during the key scan interval. Note, however, that at other intervals, it is changed after a maximum delay of one display cycle. (2) Key scan flag (KSF) The key scan flag (KSF) is set to 1 during the key scan timing and cleared automatically at other intervals. The KSF is mapped in address F8AH bit 3, can be tested bitwise, and is write-protected. Since the flag can be tested to see if the current timing is for key scan, whether or not key input data is correct can be determined. #### 5.7.6 Fluorescent indicator panel leakage glare When the $\mu$ PD75268 is used to drive a fluorescent indicator panel, leakage glare may occur. The following two causes of leakage glare are possible: (1) Short blanking time Fig. 5.7-10 shows the signal waveform when the first and second digits on 2-digit display are on and off for simplicity. If the blanking time is short as shown here, the T1 signal rises before the segment signal disappears, causing leakage glare. Generally, the blanking time required is about 20 μs. This should be considered when setting the blanking mode register. (2) Capacitance between fluorescent indicator panel segment and grid. Leakage glare may accur although enough blanking time is allowed as shown in Fig. 5.7-12. Since capacitance exists between the grid and segment of the fluorescent indicator panel (C<sub>SG</sub> in Fig. 5.7-11), the timing signal pin rises through C<sub>SG</sub> when the segment signal is turned on. If this voltage exceeds the cut-off voltage as showsn in Fig. 5.7-12, leakage glare occurs. This hair-like voltage varies according to the value of C<sub>SG</sub> and the value of internal pull-down resistor RL. As C<sub>SG</sub> goes higher and RL goes higher, the voltage becomes higher and leakage glare is likely to occur. Fig. 5.7-10 Concept of Leakage Glare Caused by Short Blanking Time Fig. 5.7-11 Leakage Glare Caused by $\mathbf{C}_{\mathrm{SG}}$ Fig. 5.7-12 Concept of Leakage Glare Caused by $\mathbf{C}_{\mathrm{SG}}$ The $C_{SG}$ value varies with the display area of the fluorescent indicator panel. As larger they are, $C_{SG}$ becomes higher. Thus, the pull-down resistor value for preventing leakage glare from occuring, varies according to the size of the fluorescent indicator panel. On the other hand, the value of the internal pull-down resistor included in the $\mu$ PD75268 by mask option is comparatively high (40-120 k $\Omega$ ) due to the limitation of power loss allowable for a flat package. Therefore, the internal pull-down resistor may be unable to suppress leakage glare. To use the $\mu$ PD75268 to drive a fluorescent indicator panel, precheck to see if $\mu$ PD75268 internal pull-down resistor can supress leakage glare on the fluorescent indicator panel by using the piggyback product or OTP version. If statisfactory display quality is not obtained, take proper countermeasures such as deepening back bias (rising $E_{\kappa}$ ), attaching a filter to the fluorescent indicator panel, or connecting an external pull-down resistor of about several 10 k $\Omega$ to the timing signal pin. The tendency toward leakage glare caused by $C_{SG}$ varies according to the duty cycle of hair -like voltage for the entire display period. The fewer the number of display digits, the more often leakage glare occurs. Likewise, a slower display controller clock is better. Dimmer select register bit 0 (DIMS0) should be set to 1. If the display intensity can be lowered slightly and if timing pins remain, the leakage glare can be reduced by setting many display digits (for example, setting 9-segment 16-digit display when the actual display is 9-segment 8 digits). #### 5.8.7 Display examples Display examples for each segment mode are given below. - (1) 10-segment mode display example: 10-segment 11-digit display (Fig. 5.7-13) - (2) 14-segment mode display example: 14-segment 10-digit display (Fig. 5.7-14) - (3) 16-segment mode display example: 16-segment 8-digit display (Fig. 5.7-15) Fig. 5.7.13 10-Segment 11-Digit Display Fig. 5.7.14 14-Segment 10-Digit Display II-2-88 Fig. 5.7-15 16-Segment 8-Digit Display #### 6. INTERRUPT OPERATION The $\mu PD75268$ have seven vector interrupt sources and two edge-detection testable inputs. The $\mu PD75268$ 's interrupt control logic has the following features to enable efficient interrupt service at high speed. - (1) Interrupt master enable flag control interrupt acknowledgement. - (2) Interrupt service start address and the MBE status during interrupt service can be freely specified on the vector table (quick start for interrupt service program). - (3) Capable of testing and clearing the interrupt request flag. - (4) Interrupt request can clear the Standby mode (Stop, Halt) (clear source is selectable by control of interrupt enable flag). ## 6.1 Configuration of the interrupt control circuit The µPD75268 has seven interrupt sources. Multiple interrupts with priority are possible. Two edge detection testable inputs are also provided. **Table 6.1-1 Kinds of Interrupt Sources** | | Interrupt Source | Internal/external | Interrupt Priority* | Vector Interrupt<br>Reuqest Signal<br>(Vector Table Address) | |--------|---------------------------------------------------------|-------------------|--------------------------------------------|--------------------------------------------------------------| | | (reference time interval signal from basic<br>al timer) | Internal | 1 | VRQ1 (0002H) | | INT4 ( | rising edge and falling edge detection) | External | | | | INT0 | (rising or falling detection edge selection) | External | 2 | VRQ2 (0004H) | | INT1 | | External | 3 | VRQ3 (0006H) | | INTSI | O (serial data transfer and signal) | Internal | 4 | VRQ4 (0008H) | | INTTO | (coincidence signal from timer/event counter 0) | Internal | 5 | VRQ5 (000AH) | | INTKS | 6 (key scan timing signal from display controller) | Internal | 7 | VRQ7 (000EH) | | INT2 ( | rising edge detection) | External | Testable input signals (set IRQ2 and IRQW) | | | INTW | (signal from watch timer) | Internal | | | <sup>\*:</sup> When multiple interrupts are generated concurrently, the interrupt order is priority order. The interrupt control circuit of the $\mu PD75268$ has the following functions: - Hardware control vector interrupt function which can control whether an interrupt is accepted or not by interrupt enable flag (IEXXX) and interrupt mask enable flag (IME). - (ii) Interrupt start address can be arbitrarily set. - (iii) Interrupt request flag (IRQXXX) test function. (Interrupt generation can be checked by software) - (iv) Standby mode release (interrupt which releases the standby mode can be selected by interrupt enable flag) Address | / laai ooo | | | | | | | |------------|---------|---|---|------------|---------------|-----------------| | 0002H | MBE 0 0 | | 0 | INTBT/INT4 | Start address | (higher 5-bits) | | · | | | | INTBT/INT4 | Start address | (lower 8-bits) | | 0004H | MBE | 0 | 0 | INT0 | Start address | (higher 5-bits) | | | | | | INT0 | Start address | (lower 8-bits) | | 0006H | MBE | 0 | 0 | INT1 | Start address | (higher 5-bits) | | | | | | INT1 | Start address | (lower 8-bits) | | 0008H | MBE | 0 | 0 | INTSIO | Start address | (higher 5-bits) | | | | | | INTSIO | Start address | (lower 8-bits) | | 000AH | MBE | 0 | 0 | INTT0 | Start address | (lower 5-bits) | | | | | | INTT0 | Start address | (higher 8-bits) | | 000EH | MBE | 0 | 0 | INTKS | Start address | (higher 5-bits) | | | | | | INTKS | Start address | (lower 8-bits) | Fig. 6.1-1 Interrupt Vector Table Example: Sets vector table for INTBT/INT4 VENT1 MBE = 0 GOTOBT ↑ ↑ ↑ Vector table at address 0002H MBE and RBE values set in the interrupt routing Symbol denoting the interrupt service routine start address Note: The address of the vector table specified by VENTn (n = 1 to 7) is address 2n. Example: Sets vector tables for INTBT/INT4 and INTT0: (program) VENT1 MBE = 0, GOTOBT VENT5 MBE = 0, GOTOT0 Fig. 6.1-2 Interrupt Control Circuit #### 6.2 Hardware for Interrupt Control Circuit (1) Interrupt request flags and interrupt enable flags The interrupt request flag (IRQXXX) is set to 1 when an interrupt request is generated and is automatically cleared to 0 when that interrupt process is executed. However, when IRQBT and IRQ4, share the vector address, the clear operation differs from this (refer to 6.6). An interrupt enable flag (IEXXX) is provided for each interrupt request flag. An interrupt is enabled when the contents are 1, and disabled when the contents are 0. A vector interrupt request (VRQn) is generated when the interrupt request flag has been set and the interrupt is enabled by the flag. This signal is also used to release the standby mode. The interrupt request and interrupt enable flags are controlled by bit manipulation and 4-bit memory manipulation instruction. If bit manipulation instruction is used, these flags can be directly controlled at any time regardless of the setting of the MBE flag. The interrupt enable flags are controlled by EI IEXXX and DI IEXXX instructions. SKTCLR instruction is normally used to test the interrupt request. Example: EI IEO ; Enable INTO DI IE1 : Disable INT1 SKTCLR IRQSIO ; Skips and is IRQSIO is 1, then clears it. If an interrupt request flag is set by instruction, a vector interrupt will be executed whether or not an interrupt is generated. An internal reset signal RES clears the interrupt request and interrupt enable flags to 0, and disables all interrupt. Table 6.2-1 Interrupt Request Flag and Interrupt Enable Flag | Interrupt<br>request<br>flag | Interrupt request flag set signal | Interrupt<br>enable<br>flag | |------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------| | IRQBT | Reference time interval signal from basic interval timer | IEBT | | IRQ4 | Detection of both rising and falling edge of INT4/P00 pin input signal | IE4 | | IRQ0 | Edge detection of INTO/P10 pin input signal. Detection edge is selected by INTO mode register (IMO) | IE0 | | IRQ1 | Edge detection ot INT1/P11 pin input signal. Detection edge is selected by INT1 mode register (IM1) | IE1 | | IRQSIO | Serial data transfer completion signal of serial interface. | IESIO | | IRQT0 | Coincidence signal from timer/event counter #0, or edge detection of Tl0 pin input by setting of mode register (TM0). | IET0 | | IRQKS | Set by Key Scan Timing signal from the display controller. | IEKS | | IRQW | Set by the signal from the clock timer. | IEW | | IRQ2 | Rising edge detection of INT2/P12 pin input signal. | - | (2) Noise eliminating circuit and edge detection mode registers Noise eliminating circuit and edge detection mode registers INT0 and INT1 are configured as shown in Fig. 6.2-1. These are external interrupt request input pins with these features: (1) eliminating noise using the sampling clock, and (2) detection edge selection. The noise eliminating circuit eliminates pulses having a pulse width narrower than the sampling clock width. As shown in Fig. 6.2-3, a pulse two times wider than the sampling clock is accepted as an interrupt request signal. INT0 can use either one of two sampling clock rates. INT1 uses CPU clock as a sampling clock. It should be noted that the inputs from INT0 and INT1 are made through each noise suppression circuit even when these pins are used for port input. The edge detection mode registers (IM0, IM1) which select the edge to be detected have the formats shown in Fig. 6.2-2. Both IM0 and IM1 are set by a 4-bit memory manipulation instruction. When the $\overline{\text{RES}}$ signal is generated, all bits of this register are cleared to 0, and the rising edge is specified as the detection edge. Fig. 6.2-1 The noise suppression circuit outputs a high level if a high level is continuously input, and outputs a low level if a low level is continuously input. Fig. 6.2-2 Edge Detection Mode Register Format Note: Up dating the Edge Detect Mode register may cause the Interrupt Request flag to be set. When doing this updating, disable interrupt after resetting the Interrupt Request flag by using the CLR1 instruction. If f<sub>xx</sub>64 is selected for the sampling clock by updating IM0, it is necessary to reset the Interrupt Request flag 16 machine cycles after updating the Mode register. Fig. 6.2-3 I/O Timing of Noise Suppression Circuit ### (2) Interrupt master enable flag (IME) The interrupt master enable flag (IME) specifies whether to enable or disable the acceptance of each interrupt. The EI/DI instruction is used to set IME. A RESET signal occurrence clears IME to 0, disabling the acceptance of any interrupts. Fig. 6.2- 4 Format of IME #### (3) Interrupt status flag The interrupt status flag (IST0), which is contained in the PSW, indicates the status of processing currently executed by the CPU. By using the content of this flag, the interrupt priority control circuit controls multiple interrupts as indicated in Table 6.2-4. A 4-bit manipulation instruction can be used to set or reset ISTO, so that multiple interrupts are enabled by changing the current status of execution. ISTO can be manipulated on a single-bit basis at any time regardless of MBE setting. Before IST $\bar{0}$ is manipulated, the DI instruction must be executed to disable interrupts, then the EI instruction must be executed to enable interrupts. ISTO is saved to stack memory together with the other PSW bits when an interrupt is accepted, then is automatically set to 1. When the RETI instruction is executed, ISTO is set to the orginal value (0). A RESET signal occurrence clears the contet of the flag 0. Table 6.2-4 ISTO and Interrupt Processing Statuses | IST0 | Status of current processing | Processing by CPU | Acceptable interrupt request | After an interrupt is accepted | |------|------------------------------|---------------------------------------------|---------------------------------|--------------------------------| | | | | | IST0 | | 0 | Status 0 | CPU is executing normal program processing. | Any interrupts can be accepted. | 1 | | 1 | Status 1 | CPU is processing interrupts. | No interrupts can be accepted. | <u>-</u> | #### 6.3 Interrupt Sequences When an interrupt occurs, it is processed using the procedure shown in Figure 6.3.-1. Fig. 6.3.-1 Interrupt Processing Sequence Note 1. IST0 is the interrupt status flag (bit 2 of the PSW). (See Table 6.2-4.) Note 2. An interrupt service program Start address and an MBE setting value at the Start of interrupt are stored in each vector table. (3) Multiple interrupts which modify the interrupt status flag As can be seen from Table 6.2-4, multiple interrupt is possible by modifying the interrupt status flag by program. That is, multiple interrupts can be generated by changing IST0 to 0 and 1 by interrupt service routine. This method is used when desiring to enable two or more multiple interrupts. IST0 is modified in the interrupt disabled state by DI instruction in advance. Fig. 6.3-2 Multi-Interrupts by Modifying Interrupt Status Flag #### 6.4 Shared Vector Address Interrupt Service Interrupt source INTBT and INT4 share the vector table . In this case, the interrupt source is selected using the methods described below. (1) To use only one interrupt source The interrupt enable flag of one of the two interrupt sources sharing the vector table is set to 1, and the other interrupt enable flag is cleared to 0. The interrupt source whose interrupt enable flag is set to 1 (IExxx = 1) generates an interrupt request. The interrupt enable flag will be reset when that interrupt request is acknowledged. (Same as interrupts with unshared vector address.) (2) To use both interrupt sources First, the interrupt enable flags corresponding to the two interrupt sources are each set to 1. An OR-ed result of the interrupt request flags of the two interrupt sources becomes the interrupt request. In this method, neither of the interrupt request flags will be reset even if the interrupt request flag settings is acknowledged. Therefore, in this case, an interrupt service routine needs to be used to determine the interrupt source generating the interrupt. This is done by executing DI instruction at the beginning of the interrupt service routine, then checking the interrupt request flag by executing SKTCLR instruction. If both of the interrupt request flags are set when tested, an interrupt request will remain, even if one of the request flags is reset. If the remaining interrupt is assigned high level interrupt, it causes double interrupt service execution to be entered. This means that the interrupt request which was not tested is serviced first. On the other hand, if the remaining interrupt is assigned low level interrupt, it is left pending. Consequently, the interrupt request which was tested will be serviced first. Therefore, the shared interrupt identification method will differ depending on whether the interrupt is a high level interrupt or not, as shown below. Table 6.4-1 Shared Interrupt Identification Methods | High level interrupt | Disable interrupts and test the interrupt request flag for the interrupt to be serviced first. | |----------------------|------------------------------------------------------------------------------------------------| | Low level interrupt | Test the interrupt request flag for the interrupt to be serviced first. | Example 1: Use both INTBT and INT4 as high level interrupts and service INT4 first: DI SKTCLR IRQ4 ; IRQ4 = 1?BR VSUBBT INT4 service routine ΕI RETI VSUBBT: CLR<sub>1</sub> IRQBT INTBT service routine ΕI RETI Use both INTBT and INT4 as low level interrupts and service INT4 first: Example 2: SKTCLR IRQ4 ; IRQ4 = 1BR **VSUBBT** INT4 service routine RETI VSUBBT: CLR1 **IRQBT** INTBT service routine RETI ### 6.5 Machine Cycles before Interrupt Service Start The following shows the machine cycle required on the $\mu$ PD75268 after an interrupt request flat is set and before the execution of the interrupt service routine is started: (1) IRQn was set when a manipulation instruction to data memory address FBXH (interrupt hardware) was executed: ### FBXH address manipulation instruction Interrupt routine service is started in a maximum of six machine cycles after handling instruction of data memory address FBXH (described above) terminates. (If FBXH address handling instructions are contiguous, interrupt routine service is started in a maximum of six machine cycle after the last handling instruction terminates.) (2) IRQn was set when an instruction other than that given in (1) was executed: This case requires up to 6 machine cycles max. # 6.6 Effective Use of Interrupts cycles of instruction) Note the following for effective use of interrupts: (1) Set MBE = 0 in an interrupt service routine: The programmer need not be aware of memory bank configuration when programming if he or she uses addresses 0 through 7FH of the data memory in interrupt service routines and specifies MBE = 0 on the interrupt vector table. If memory bank 1 must be used for programming convenience, save the memory bank select register value by using the PUSH If memory bank 1 must be used for programming convenience, save the memory bank select register value by using the PUSI BS instruction before selecting memory bank 1. (2) Use software interrupt for debugging: If an interrupt request flag is set by an instruction, the CPU operates as if an interrupt had occurred. Debugging for irregular interrupt service or more than one interrupt occurred at the same time can be efficiently done by setting the interrupt request flag with an instruction. #### 6.7 Applications of Interrupt To make the interrupt function available, do the following setup in the main program: - (1) Set the interrupt enable flag to be used (EI IEXXX instruction). - (2) When using INT0 or INT1, select active edge (set IM0 or IM1). - (3) Set the interrupt master enable flag (El instruction). For an interrupt service program, the MBE is set by the vector table, therefore no register save/restore operation is needed, and the execution of the interrupt service program can be immediatly started. Use the RETI instruction to return control from the interrupt service program to the main program. ### (1) Enable/disable interrupt - 1) Reset (RES) disable all interrupts. - ② The El IEXXXinstruction sets an interrupt enable flag. At this point all interrupts are still disabled. - The El instruction sets the interrupt master enable flag. This enables INTO and INTTO. - The DI IEXXX instruction clears the interrupt enable flag, which disables INTO. - ⑤ The DI instruction disables all interrupts again. (2) Example using INTBT, INTO (falling edge active) and INTTO. - ① Reset disables all interrupts and selects status 0. - 2 Sets INT0 for falling edge active. - ③ Enables interrupt with the EI IEXXX and EI instructions. - (a) INTO interrupt service program is started at the falling edge of INTO. The status is set to one and all interrupts are disabled. - The RETI instruction returns control from the interrupt service program to main program. The status returns to 0 and all interrupts are enabled again. (3) Execution of pending interrupt - interrupt input during interrupt disable state - ① If INT0 is set during interrupt disable state, the interrupt request flag remains pending. ② The INT0 service program is started when interrupt is enabled by the El instruction. <sup>3</sup> Same as 1 above. The INTSIO service program is started when the suspended INTSIO is enabled. (4) Execution of pending interrupt - two low-level interrupts occuring at the same time - ① If two low-level interrupts INT0 and INTT0 occured at the same time (during execution of the same instruction), the INT0 with a higher priority will be serviced first (INTT0 remains pending): - The execution of the INTT0 service program which was pending is initiated when the INT0 service program is ended by the RETI instruction. (5) Enable two double interrupts - INTT0 and INT0 enable double interrupt while INTSIO and INT4 enable single interrupt.- ① If an INTSIO for which double interrupt is not enabled has occured, the INTSIO service program is started with the status set to one. ② IST0 is cleared to reset status to 0. The INTSIO and INT4 for which double interrupt is not enabled are disabled. <sup>3</sup> Double interrupt is serviced when the INTTO occured. The status is set to 1 to disable all interrupts. Status returns to 0 when the INTT0 service is completed. <sup>(5)</sup> The INTSIO and INT4 are enabled and control returns to the main program. ### 7. STANDBY FUNCTION To make the most of low current consumption, which is one feature of the CMOS process, the µPD75268 can stop CPU operation in the standby mode making current consumption by the CPU very small. The uPD75268 standby mode includes the STOP mode and HALT mode. The STOP mode stops the main system clock oscillator. In this mode, CPU current consumption consists almost entirely of leakage current. Data memory can also be held with low supply voltage (up to $V_{DD} = 2$ V). This features is useful for maintaining the data memory contents with very low current consumption. Since the $\mu$ PD75268 STOP mode can be released by using an interrupt request, intermittent operation can also be performed. However, if processing must be started immediately when an interrupt request is made, note that the wait time required to ensure oscillator stability is taken when the STOP mode is released. The HALT mode continues system clock oscillator operation but stops the CPU clock $(\Phi)$ supply; thus, CPU operation is stopped. Although the HALT mode is inferior to the STOP mode for reduction of current consumption, it is useful to restart processing immediately according to an interrupt request or for performing intermittent operations such as watch operation. In either mode, all the register, flag, and data memory contents immediately before the standby mode is entered are held. The input/output port output latch state and output buffer state are also held. The input/output port state is handled beforehand so that the current consumption of the entire system is minimized. #### Cautions on Use of Standby Mode: - The STOP mode can be used only when μPD75268 operation uses the main system clock. (Subsystem clock oscillation cannot be stopped.) The HALT mode can be used when the μPD75268 uses either main system or subsystem clock. - If STOP mode is selected when the FIP controller/driver is operating, a malfunction may occur. Stop these hardware operations before selecting STOP mode. - 3. Although efficient operation with low current consumption and low voltage can be performed by using the clock change function between the CPU and system clocks in combination with the standby mode, time (described in 5.2.3) is required from selection of a new clock by setting the control register until operation is started by the newly selected clock. Thus, to use the clock change function and the standby mode in combination, set the standby mode within the time required for the clock change. ### 7.1 Standby Mode Setting and Operating State Table 7.1-1 Operating State in Standby Mode | | 1 | STOP mode | HALT mode | |----------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------| | Setting instruction | | STOP instruction | HALT instruction | | System clock when standby mode is set. | | Can be set only during main system clock. | Can be set during either main system or subsystem clock. | | Clock oscillator | | Only the main system clock oscillator is stopped. | Only CPU clock $\Phi$ is stopped (oscillation is continued). | | | Basic interval timer | Operation stop | Operation (IRQBT is set at reference time intervals.) | | | Serial interface | Can operate only when external SCK input is selected for serial clock. | Can operate, when clock other than $\Phi$ is selected. | | Operating state | Timer/event counter | Can operate only when TI0 pin input is selected for count clock. | Can operate. | | | Watch timer | Can operate when $f_{XT}$ is selected for count clock. | Can operate. | | | FIP controller | Disabled! | | | | CPU | Operation stop | | | Data to be retained | | Data is retained in all register and data memory, such as general-purpose registers, flags, mode registers, and output latches which are not operating in Standby mode. | | Table 7.1-1 Operating State in Standby Mode (cont'd) | | STOP mode | HALT mode | |----------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | Release signal | Interrupt request signals (except INT0, INT1, and INT2) being enabled by the interrupt enable flag or the RESET input. | Interrupt request signals (except INT0, INT1, and INT2) being enabled by the interrupt enable flag or the RESET input. | The STOP mode is set by using the STOP instruction to set PCC bit 3; the HALT mode is set by the using HALT instruction to set PCC bit 2. To change the CPU clock by using the low-order two bits of PCC, a time lag may occur from PCC rewrite to CPU clock change. Thus, to change the clock before the standby mode is entered or after the standby mode is released, set the standby mode within the number of machine cycles required to change the CPU clock after PCC is rewritten. While operation stops during the standby mode, data is held in all registers and data memory such as general-purpose registers, flags, mode register, and output latches. Caution: 1. When the STOP mode is set, X1 input is short-circuited to V<sub>SS</sub> (GND potential) internally to suppress crystal oscillator leakage. Therefore, so not use the STOP mode in a system using external clock as a main system slock. 2. Since an interrupt request signal is used to release the standby mode, if both interrupt request and enable flags are set for an interrupt source, the standby mode is immediately released. Thus, for the STOP mode, the HALT mode is entered immediately after execution of the STOP instruction, a wait is followed according to the setup time of the BTM register, then a return is made to the opertion mode. #### 7.2 Standby Mode Release The standby mode (STOP or HALT) is released when an interrupt request signal (except INT0) enabled with an interrupt enable flag occurs or RESET is input. Fig. 7.2-1 shows the standby mode release operation. Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (cont'd) If the STOP mode is released when an interrupt occurs, the wait time is determined by BTM setting. (See Table 7.2-1.) The time until oscillation becomes stable varies according to the type of oscillator being used and the supply voltage when the STOP mode is released. Therefore, select the wait time according to the conditions of use and set BTM before setting the STOP mode. Table 7.2-1 Wait Time Selection by Using BTM | втмз | BTM2 | ВТМ1 | ВТМ0 | Wait time* ( ) indicates f <sub>XX</sub> = 4.19 MHz | |---------|------------------|------|------|------------------------------------------------------------| | - | 0 | 0 | 0 | APPROX. 2 <sup>20</sup> /f <sub>xx</sub> (Approx. 250 ms) | | - | 0 | 1 | 1 | APPROX. 2 <sup>17</sup> /f <sub>xx</sub> (Approx. 31.3 ms) | | - | 1 | 0 | 1 | APPROX. 2 <sup>15</sup> /f <sub>XX</sub> (Approx. 7.82 ms) | | - | 1 | 1 | 1 | APPROX. 2 <sup>13</sup> /f <sub>xx</sub> (Approx. 1.95 ms) | | Other t | Other than above | | | Use Prohibited | Note: The wait time when STOP mode is released does not include the time until the clock begins to <u>oscillate</u> after STOP mode is released ((a) in the figure below) regardless of whether STOP mode was released by RESET input or interrupt generation. ## 7.3 Operation After Standby Mode is Released - (1) If the standby mode is released when RESET is input, normal reset operation is performed. - (2) If the standby mode is released when an interrupt request occurs, the contents of the interrupt master enable flag (IME) determine whether or not a vectored interrupt is made when the CPU restarts instruction execution. - (a) When IME = 0 After the standby mode released, execution restarts at the NOP instruction next to the standby mode setting instruction. The interrupt request flags are held. (b) When IME = 1 After the standby mode is released, two instructions following the standby mode setting instruction are executed before a vectored interrupt is executed. However, if the standby mode is released by using INTW (testable input), no vectored interrupt will occur; processing as in (a) above is performed. # 7.4 Standby Mode Application To use the standby mode, follow the procedure described below: - Detect a standby mode setting source such as interrupt input or port input for power off (it is effective to use INT4 for power off detection). - 2) Handle input/output ports so that current consumption is minimized. - Specify interrupt to release the standby mode. (It is effective to use INT4. Clear the interrupt enables flags so as not to release the standby mode.) - 4) Specify operation after the standby mode is released (set IME depending on whether or not interrupt service is made). - 5) Specify the CPU clock after the standby mode is released. (To change the clock, wait for the required number of machine cycles before setting the standby mode.) - 6) Select the wait time in release of standby mode. - 7) Set the standby mode by using the STOP or HALT instruction. Use of the standby mode and system clock change function in combination enables the $\mu$ PD75268 to operate at low current consumption and low voltage. # (1) Example of STOP mode application Use the STOP mode under the following conditions - Set the STOP mode when the INT4 falling edge is input and release it when the rising edge is input. (Do not use INTBT.) - Place all input/output ports in high impedance. - Use interrupts INTO and INTTO in the example program; however, do not use them to release the STOP mode. - Enable interrupts after the STOP mode is released. - After the STOP mode is released, start operation on the minimum speed CPU clock, and in 250 ms, change it to high-speed clock. - Set the wait time for STOP mode release to about 31.3 ms. - After the STOP mode is released, wait for 31.3 ms for the power supply to become stable. Check the P00/INT4 pin twice and remove chattering. #### (2) HALT mode application Perform intermittent operation under the following conditions - Change to the subsystem clock on the falling edge of INT4. - Stop oscillation of the main system clock and set the HALT mode. - Perform intermittent operation at 0.5sec. intervals during the standby mode. - Again change to the main system clock on the rising edge of INT4. - Do not use INTBT. | | SKT | PORT0.0 | ; Check chattering | |--------|------|----------|-----------------------------------------| | | BR | PDOWN | | | | CLR1 | SCC.0 | ; Change to main system clock | | | MOV | XA, #04H | ; Main system clock | | | MOV | WM, XA | | | | RETI | | | | PDOWN: | MOV | XA, #05H | ; Subsystem clock | | | MOV | WM, XA | | | | MOV | XA, #00H | | | | MOV | DSPM, A | ; FIP display off | | | SET1 | SCC.0 | ; Change to subsystem clock | | | MOV | A, #6 | | | WAIT2: | INCS | Α | ; Wait for 32 machine cycles | | | BR | WAIT2 | | | | SET1 | SCC.3 | ; Stop oscillation of main system clock | | | RETI | | • | | | | | | Note: When the system clock is changed after power on from main system clock to subsystem clock, change the system clock after the subsystem clock is stabilized. ### 8. RESET OPERATION The $\mu$ PD75268 is reset by $\overline{\text{RESET}}$ signal input. When the $\mu$ PD75268 is reset, the devices are initialized as indicated in Table 8-1. Figure 8-1 shows the timing of reset operation. Fig. 8.1-1 Reset Operation by RESET input Table 8.1-1 Status of Each Hardware After Reset | Hardware Program counter (PC) | | RESET input while in standby mode | RESET input while in operation mode or power-on reset. | | |--------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------|--| | | | Sets the lower 5 bits of address 0000H to PC 12 - 8 and the contents of address 0001H to PC7-0. | same as the left | | | | Carry flag (CY) | Retained | Undefined | | | PSW | Skip flags (SK0-2) | 0 | 0 | | | | Interrupt status<br>flags (IST0) | 0 | 0 | | | | Bank enable flags<br>(MBE) | Sets the contents of bit 7 of address 0000H of the program memory to the MBE flag. | same as the left | | | Stack pointer (SP) | | Undefined | Undefined | | | Data memory (RAM) | | Retained (Note 1) | Undefined | | | General-purp<br>(X, A, H, L, E | oose registers<br>0, E, B, C) | Retained | Undefined | | | Bank selection | on registers (MBS) | 0 | 0 | | | Basic in- | Counter (BT) | Undefined | Undefined | | | terval timer | Mode register (BTM) | 0 | 0 | | | Timer/ | Counter (T0) | 0 | 0 | | | event | Mode register (TMOD0) | FFH | FFH | | | counter | Mode register (TM0) | 0 | 0 | | | Watch timer | Mode register (WM) | 0 | 0 | | | Serial | Shift register (SIO) | Retained | Undefined | | | interface | Mode register (SIOM) | Bit 4 is set to 1 all other bits are 0 | same as left | | Table 8.1-1 Status of Each Hardware After Reset (Cont'd) | | Hardware | RESET input while in standby mode | RESET input while in operation mode or power-on reset. | |-------------|----------------------------------------|-----------------------------------|--------------------------------------------------------| | Clock | Processor clock control register (PCC) | 0 | 0 | | generator | System clock control register (SCC) | 0 | 0 | | | Interrupt request flag (IRQXXX) | Reset (to 0) | Reset (to 0) | | Interrupts | Interrupt enable flag (IEXXX) | 0 | 0 | | | Interrupt master enable fag (IME) | 0 | 0 | | | INT0, 1 mode register (IM0, IM1) | 0,0 | 0,0 | | | Output buffer | Off | Off | | Digital | Output latch | Cleared (to 0) | Cleared (to 0) | | port | Input output mode register (PMGA, B) | 0 | 0 | | Port H | Output latches | Retained | Undefined | | FIP | Mode register | 0 | 0 | | controller/ | Display data memory | Retained | Undefined | | driver | Output buffers | Off | Off | Notes 1: Data in address 0F8H to 0FDH of the data memory becomes undefine under the RESET signal is input. # 9. ELECTRICAL CHARACTERISTICS # Absolute Maximum Ratings ( $T_a = 25$ °C) | Item | Symbol | Conditions | Rating | Units | |---------------------------|-------------------|--------------------------------------|---------------------------------------------|-------| | Power supply voltage | V <sub>DD</sub> | | -0.3 to +7.0 | ٧ | | | V <sub>LOAD</sub> | | V <sub>DD</sub> -40 to V <sub>DD</sub> +3.0 | ٧ | | | V <sub>PRE</sub> | | V <sub>DD</sub> -12 to V <sub>DD</sub> +0.3 | V | | Input voltage | V <sub>I</sub> | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | Output voltage | v <sub>o</sub> | Other than display output pins | -0.3 to V <sub>DD</sub> +0.3 | V | | | V <sub>OD</sub> | Display output pins | V <sub>DD</sub> -40 to V <sub>DD</sub> +0.3 | ٧ | | High level output current | loh | 1 pin other than display output pins | -15 | mA | | | | S0 to S9 1 pin | -15 | mA | | : | | T0 to T15 1 pin | -30 | mA | | | | Total other than display output pins | -20 | mA | | | | Display output pins total | -120 | mA | # Absolute Maximum Ratings (Cont'd) $(T_a = 25^{\circ}C)$ | ltem a | Symbol | Conditions | Rating | Units | |---------------------------|------------------|--------------------|-------------|-----------| | Low level output current | I <sub>OL</sub> | 1 pin | 17 | mA | | | | All pins total | 60 | mA | | Total loss (Note 1) | P <sub>T</sub> | Plastic flat | 450 | mW | | | an dat fo | Plastic shrink DIP | 600 | mW | | Operating temperature | T <sub>opt</sub> | | -40 to +85 | °C | | range | | e filozofia kaj li | | 2 - 1 - 1 | | Storage temperature range | T <sub>stg</sub> | | -65 to +150 | °C | ### Operation Power Supply Voltage (T<sub>a</sub> = -40 to +85°C) | Item | Conditions | Min. | Max. | Units | |-------------------------|------------|----------|------|-------| | CPU (Note 2) | | (Note 3) | 6.0 | ٧ | | Display controller | | 4.5 | 6.0 | V | | Other hardware (Note 2) | | 2.7 | 6.0 | V | ### Note 1: Total loss calculation method The $\mu$ PD75268CW/GF has the three power losses listed below. Make the design such that the sum of these three power losses is less than the total loss $P_{\tau}$ . (Use below 80% of the rating is recommended.) (1) CPU loss: Calculate from V<sub>DD</sub> (Max.) x I<sub>DD1</sub> (Max.). 2) Output pins loss: This includes normal outputs and display outputs. The loss when the maximum current flows in each output pin must be added. 3 Pull-down resistor loss: This is the loss generated by the on-chip display output pins pull-down resistors specified by mask option. Example: 9SEG x 11DIGIT, 4LED output, $V_{DD}$ = 5V +10%, 4.19 MHz oscillation. Assume that the maximum current flowing in the segment pins is 3 mA, the maximum current flowing in the timing pin is 15 mA, and the maximum current flowing in the LED output pins is 10 mA. Make the FIP voltage (V<sub>I OAD</sub> voltage) -30 V. Make the loss of the normal outputs low. CPU loss: 5.5 V x 9.0 mA = 49.5 mW Pins loss: Segment pins ... 2 V x 3 mA x 9 = 54 mW Timing pin ... 2V x 15 mA = 30 mW LED output ... (10/15 x 2 V) x 10 mA x 4 = 53 mW Pull-down registers loss: $\frac{(30 + 5.5\text{V})^2}{40 \text{ k}\Omega} \times 10 = 315 \text{ mW}$ $P_T = 1 + 2 + 3 = 501.5 \text{ mW}$ For this example, because the allowable total loss for a shrink DIP package is 600 mW, the 501.5 mW power consumption is no problem. However, because the allowable total loss for a flat package is 450 mW, the power consumption must be lowered. The power consumption can be lowered by making the number of on-chip pull-down resistors small. For this example, the power consumption can be suppressed to 344 mW by providing an on-chip pull-down resistor at 11 of the digit outputs and four of the segment outputs and installing external pull-down resistors for the remaining five segment outputs. Note 2: Display controller excluded. Note 3: The power supply voltage range at which operation is possible differs with the cycle time. See the AC characteristics. Main System Clock Oscillator Charactaristics (Ta = -40°C to + 85°C, V<sub>DD</sub> = 2.7 to 6.0 V) | Resonator | Recommended<br>Constants | Item | Test<br>Conditions | Min. | Тур. | Мах. | Unit | |------------------------------------|--------------------------|--------------------------------------------------------------------|----------------------------------------------------------------|------|------|------|------| | Ceramic<br>oscillator<br>(Note 3) | X1 | Oscillator frequency (f <sub>XX</sub> ) (Note 1) | V <sub>DD</sub> = oscillator voltage<br>range | 2.0 | | 5.0 | MHz | | (13.5 5) | | Oscillator stabilization time (Note 2) | After V <sub>DD</sub> reached Min. of oscillator voltage range | | | 4 | ms | | Crystal re-<br>sonator<br>(Note 3) | x1 x2 | Oscillator frequency (f <sub>xx</sub> ) (Note 1) | | 2.0 | 4.19 | 5.0 | MHz | | (Note 5) | | Oscillator stabilization time (Note 2) | V <sub>DD</sub> = 4.5 to 6.0 V | | | 10 | ms | | | | | | | | 30 | ms | | Exteral clock | X1 X2 | X1 input frequency (f <sub>x</sub> ) (Note 1) | | 2.0 | | 5.0 | MHz | | | μPD74HCU04 | X1 input high/low level width (t <sub>XH</sub> , t <sub>XL</sub> ) | | 100 | | 250 | ns | Note 1: Oscillator frequency and input frequency are oscillator characteristics only. For the instruction execution time, see the AC characteristics. Note 2: Oscillator stabilization time is the time required for oscillation to stabilize after V<sub>DD</sub> is applied or the STOP mode is Note 3: The resonators shown below are recommended. # Subsystem Clock Oscillator Characteristics ( $T_a = -40 \text{ to } +85^{\circ}\text{C}, V_{DD} = 2.7 \text{ to } 6.0 \text{ V}$ ) | Resonator | Recommended Constants | Item | Test Conditions | | Тур | Max. | Unit | |-------------------|-----------------------|-----------------------------------------------------------------------|-----------------------------------|----|--------|------|------| | Crystal resonator | XT1 XT2 | Oscillator frequency (f <sub>XT</sub> ) (Note 1) | | 32 | 32.768 | 35 | kHz | | | 22 pF + 10 + 33 pF | Oscillator stabilization (Note 2) | V <sub>DD</sub> = 4.5<br>to 6.0 V | | 1.0 | 2 | S | | | <i>m m</i> | ** | | | | 10 | s | | External clock | XT1 XT2 Open | XT1 input frequency (f <sub>XT</sub> ) | | 32 | | 100 | kHz | | | Å Open | XT1 input high/low level width (t <sub>XTH</sub> , t <sub>XTL</sub> ) | | 10 | | 32 | μs | Note 1: Oscillator frequency and input frequency are oscillator characteristics only. For the instruction execution time, see the AC characteristics. Note 2: Oscillator stabilization time is the time required for oscillation to stabilize after $V_{DD}$ is applied. ### Capacitance (T<sub>a</sub> = 25°C, V<sub>DD</sub> = 0V) | | Item | Symbol | Test Conditions | Min. | Тур | Мах. | Unit | |--------------------|---------------------------|------------------|------------------------------------------|------|-----|------|------| | Input capacitance | | C <sub>IN</sub> | | | | 15 | pF | | Output capacitance | Other than display output | C <sub>OUT</sub> | f = 1 MHz<br>other than measured pin 0 V | | | 15 | pF | | | Display output | | other than measured pin o | | | 35 | pF | | I/O capacitance | | C <sub>IO</sub> | | | | 15 | pF | # Recommeded Oscillator Constants Main System Clock: Ceramic (T $_a$ = $-40\ to\ +85^{\circ}C)$ | Manufast | Due do et Nesses | External Cap | acitance (pF) | Oscillator Volta | age Range (V) | | |-------------------|----------------------------------------|--------------|---------------|------------------|---------------|----------------| | Manufacturer | Product Name | C1 | C2 | Min. | Max. | Remarks | | Murata Seisakusho | CSA 2.00MG<br>CSA 4.19MG<br>CSA 4.91MG | 30 | 30 | 4.0 | 6.0 | | | | CAT 2.00MG<br>CST 4.19MG<br>CST 4.91MG | Unnecessary | Unnecessary | | | On-chip C type | | Kyocera | KBR-2.0MS | 47 | 47 | 4.0 | 6.0 | | | | KBR-4.0MS<br>KBR-4.19MS<br>KBR-4.91MS | 33 | 33 | | | | | TDK | FCR 3.58M2<br>FCR 4.00M2<br>FCR 4.19M2 | 30 | 30 | 4.0 | 6.0 | | | | FCR 4.19MC | Unnecessary | Unnecessary | · | | On-chip C type | Main System Clock $X_{TAL}$ ( $T_a = -40 \text{ to } +85^{\circ}\text{C}$ ) | Manufacturer | Frequency | ncy Holder Considered | | Exte<br>Capacita | | Osci<br>Voltage F | | Remarks | |--------------|----------------------|-------------------------------|----|------------------|------|-------------------|-----|---------| | | | Capacitance (pF) | C1 | C2 | Min. | Max. | | | | Kinseki | 2.00<br>4.19<br>4.91 | HC-18/U<br>HC-49/U<br>HC-43/U | 16 | 20 | 20 | 4.0 | 6.0 | | Subsystem Clock: 32.768 kHz $X_{TAL}$ ( $T_a = -10 \text{ to } +60^{\circ}\text{C}$ ) | | Time | Load Capacitance | External Circuit Constants | | | Oscillator Vo | | | |---------------|---------------------|------------------|----------------------------|---------|--------|---------------|----------|---------| | Manufacturer | Type<br>Disignation | CL (pF) | C1 (pF) | C2 (pF) | R (kΩ) | Min. (V) | Max. (V) | Remarks | | Kinseki | P-3 | 12 | 22 | 22 | 330 | 2.7 | 6.0 | | | Citizen Watch | CFS-308 | 14 | 22 | 33 | 330 | 2.7 | 6.0 | | Note: Fine adjust the oscillator frequency of crystal resonator at external capacitance C1. DC Characteristics ( $T_a = -40 \text{ to } +85^{\circ}\text{C}, V_{DD} = 2.7 \text{ to } 6.0 \text{ V}$ ) | Item | Symbol | Tes | st Conditions | Min. | Тур | Max. | Unit | |----------------------------------|-------------------|---------------------------|-----------------------------------------------------------------------|----------------------|-----|---------------------|------| | High level input | V <sub>IH1</sub> | Other than below | | 0.7 V <sub>DD</sub> | | V <sub>DD</sub> | V - | | input voltage | V <sub>IH2</sub> | Port 0, 1, RESET | | 0.75 V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | V <sub>IH3</sub> | X1, X2, XT1 | | V <sub>DD</sub> -0.4 | | V <sub>DD</sub> | ٧ | | | V <sub>IH4</sub> | Port 6 | V <sub>DD</sub> = 4.5 to 6.0 V | 0.65 V <sub>DD</sub> | | V <sub>DD</sub> | V | | | | | | 0.7 V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | Low level input | V <sub>IL1</sub> | Other than below | | 0 | | 0.3 V <sub>DD</sub> | V | | input voltage | V <sub>IL2</sub> | Port 0, 1, 6, RESET | | 0 | | 0.2 V <sub>DD</sub> | ٧ | | | V <sub>IL3</sub> | X1, X2, XT1 | | 0 | | 0.4 | V | | High level output voltage | V <sub>OH</sub> | All output pins | $V_{DD} = 4.5 \text{ to } 6.0 \text{ V},$<br>$I_{OH} = -1 \text{ mA}$ | V <sub>DD</sub> -1.0 | | : | ٧ | | | | | I <sub>OH</sub> = -100 μA | V <sub>DD</sub> -0.5 | | | ٧ | | Low level output voltage | V <sub>OL</sub> | Port 4, 5 | V <sub>DD</sub> = 4.5 to 6.0 V,<br>I <sub>OL</sub> = 15 mA | | 0.4 | 2.0 | ٧ | | | | All output pins | V <sub>DD</sub> = 4.5 to 6.0 V,<br>I <sub>OL</sub> = 1.6 mA | | | 0.4 | V | | | | | I <sub>OL</sub> = 400 μA | | | 0.5 | ٧ | | High level input leakage current | I <sub>LIH1</sub> | Other than<br>X1, X2, XT1 | $V_{IN} = V_{DD}$ | | | 3 | μА | | | I <sub>LIH2</sub> | X1, X2, XT1 | | | | 20 | μА | | Low level input leakage current | I <sub>LIL1</sub> | Other than<br>X1, X2, XT1 | I IN | | | <u>–3</u> | μА | | | I <sub>LIL2</sub> | X1, X2, XT1 | | | | -20 | μА | # **DC Characteristics (Cont'd)** $(T_a = -40 \text{ to } +85^{\circ}\text{C}, V_{DD} = 2.7 \text{ to } 6.0 \text{ V})$ | Item | Symbol | Tes | t Conditions | | Min. | Тур | Max. | Unit | |-----------------------------------|-------------------|------------------------------------------|--------------------------------------|--------------------------------------------------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | High level output leakage current | I <sub>LOH</sub> | All output pins | $V_{OUT} = V_{DD}$ | | | | 3 | μА | | Low level output leakage current | I <sub>LOL1</sub> | Other than display output | V <sub>OUT</sub> = 0V | | | | -3 | μА | | | I <sub>LOL2</sub> | Display output | V <sub>OUT</sub> = V <sub>LOA</sub> | <sub>D</sub> = V <sub>DD</sub> -35 V | | | -10 | μА | | Display output current | I <sub>OD</sub> | S0 to S9 | V <sub>DD</sub> = 4.5<br>to 6.0 V | V <sub>PRE</sub> = (Note 1)<br>V <sub>DD</sub> -9 ±1 V | -3 | -5.5 | and the second of o | mA | | | | | $V_{OD} = V_{DD}$ | V <sub>PRE</sub> = 0V | -1.5 | -3.5 | | mA | | | | T0 to T15 | -2 V | V <sub>PRE</sub> = (Note 1)<br>V <sub>DD</sub> -9 ±1 V | -15 | -22 | | mA | | | | | | V <sub>PRE</sub> = 0 V | -7 | -15 | | mA | | On-chip pull- | R <sub>P6</sub> | Port 6 V <sub>IN</sub> = V <sub>DD</sub> | V <sub>DD</sub> = 4.5 to | 6.0 V | 20 | - 80 | 200 | kΩ | | down resistor<br>(mask option) | | | | | 20 | | 1000 | kΩ | | | R <sub>L</sub> | Display output | V <sub>OD</sub> - V <sub>LOAD</sub> | = 35 V | 25 | 70 | 135 | kΩ | | Power supply | I <sub>DD1</sub> | 4.19 MHz crystal | V <sub>DD</sub> = 5 V ± 10% (Note 3) | | | 3.0 | 9.0 | mA | | voltage (Note 2) | | oscillation<br>C1 = C2 = 15 pF | $V_{DD} = 3 V \pm$ | 10% (Note 4) | | 0.55 | 1.5 | mA | | | I <sub>DD2</sub> | | HALT mode | V <sub>DD</sub> = 5 V ± 10% | | 600 | 1800 | μА | | | | | | V <sub>DD</sub> = 3 V ± 10% | | 200 | 600 | μА | | | I <sub>DD3</sub> | 32 kHz (Note 5) | V <sub>DD</sub> = 3 V ± | 10% | | 40 | 120 | μА | | | I <sub>DD4</sub> | crystal<br>oscillation | HALT mode | V <sub>DD</sub> = 3 V ± 10% | | 5 | 15 | μА | | | I <sub>DD5</sub> | XT1 = 0 V | V <sub>DD</sub> = 5 V ± 10% | | | 0.1 | 20 | μА | | | STOP mode | | V <sub>DD</sub> = 3 V ± | V <sub>DD</sub> = 3 V ± 10% | | 0.1 | 10 | μА | Note 1: The external circuit shown below is recommended. Note 2: Current flowing in on-chip pull-down resistors is not included. Note 3: When 0011 set in processor clock control register (PCC) and operated in high-speed mode. Note 4: When 0000 set in PCC and operated in low-speed mode. Note 5: When 1001 set in system clock control register (SCC) and main system clock stopped and system operated by subsystem clock. # AC Characteristics ( $T_a = -40 \text{ to } +85^{\circ}\text{C}, \ V_{DD} = 2.7 \text{ to } 6.0 \text{ V}$ ) | Item | Symbol | Test C | onditions | Min. | Тур | Max. | Unit | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------|--------------------------------|------------------------------|-----|------|------| | Cycle time (minimum instruction | t <sub>CY</sub> | Operated by main | V <sub>DD</sub> = 4.5 to 6.0 V | 0.95 | | 32 | μs | | execution time) (Note 1) | | system clock | | 3.8 | | 32 | μs | | | | Operated by subsyst | em clock | 114 | 122 | 125 | μs | | TI0 input frequency | f <sub>TI</sub> | V <sub>DD</sub> = 4.5 to 6.0 V | | 0 | | 0.6 | MHz | | | | | | 0 | | 165 | kHz | | TI0 input high/low level width | t <sub>TIH</sub> , t <sub>TIL</sub> | V <sub>DD</sub> = 4.5 to 6.0 V | | 0.83 | | | μs | | | | | | 3 | | | μs | | SCK cycle time | t <sub>KCY</sub> | V <sub>DD</sub> = 4.5 to 6.0 V | input | 0.8 | | | μs | | | | ar e | output | 0.95 | | | μs | | | 1 | - | input | 3.2 | | 4 | μs | | | | | output | 3.8 | | | μs | | SCK high/low level width | t <sub>KH</sub> , t <sub>KL</sub> | V <sub>DD</sub> = 4.5 to 6.0 V | input | 0.4 | | | μs | | | | | output | t <sub>KCY</sub> /2<br>- 50 | | | ns | | The world of the second | | | input | 1.6 | | | μs | | e de la companya l | | | output | t <sub>KCY</sub> /2<br>- 150 | | | ns | AC Characteristics (Cont'd) $(T_a = -40 \text{ to } +85^{\circ}\text{C}, V_{DD} = 2.7 \text{ to } 6.0 \text{ V})$ | Item | Symbol | Te | est Conditions | Min. | Тур | Max. | Unit | |-----------------------------------------------------|------------------|--------------------------------|----------------|------------------|-----|------|------| | SI setup time (for SCK ↑) | t <sub>sıκ</sub> | | | 100 | | | ns | | SI hold time (for SCK ↑) | t <sub>KSI</sub> | | | 400 | | | ns | | $\overline{SCK}\downarrow \to SO$ output delay time | t <sub>kso</sub> | $V_{DD} = 4.5 \text{ to } 6.0$ | | | 300 | ns | | | | ľ | | | | | 1000 | ns | | Interrupt input high/low level width | tintl, | | INT0 | (Note2) | | | μs | | | | a at 1 se | INT1 | 2t <sub>CY</sub> | | | μs | | | | | INT2, 4 | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | | 10 | | | μs | Note 1: The cycle time (minimum instruction execution time) is determined by the oscillator frequency of the connected resonator and the system clock control register (SCC) and processor clock control register (PCC). The cycle time t<sub>CY</sub> versus power supply voltage V<sub>DD</sub> characteristics at main system clock operation is shown in the figure Note 2: Becomes 2t<sub>CY</sub> or 128/f<sub>XX</sub> by interrupt mode register (IM0) setting. AC Timing Test Points (Except PORT0, 1, TI0, X1, X2, XT1, RESET) 0.2 V<sub>DD</sub> Clock Timing Serial Transfer Timing Interrupt Input Timing RESET Input Timing ## Data Memory STOP Mode Low Supply Voltage Data Retention Characteristics ( $Ta = -40 \text{ to } +85^{\circ}\text{C}$ ) | Parameter | Symbol | Test Conditions | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|------------------------------------|------|---------------------------------|------|------| | Data Retention Supply Voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data Retention Supply Current | I <sub>DDDR</sub> | V <sub>DDDR</sub> = 2.0V | | 0.1 | 10 | μА | | Release Signal Set Time | t <sub>SREL</sub> | | 0 | | | μs | | Oscillation Stable Wait Time (1) | t <sub>wait</sub> | When released by RESET | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | | 1 1, 1 | When released by Interrupt Request | | (2) | | ms | Note 1: During Oscillation Stable Wait Time, CPU operation must be stopped to avoid unstable operation at oscillation start. | Note | 2 | |------|---| |------|---| | втмз | ВТМ2 | BTM1 | втмо | tWAIT ( ): at f <sub>XX</sub> =4.19MHz | |------|------|------|------|---------------------------------------------------| | - | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>XX</sub> (approx. 250ms) | | - | 0 | 1 | 1 | 2 <sup>17</sup> /f <sub>XX</sub> (approx. 31.3ms) | | - | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>XX</sub> (approx. 7.82ms) | | - | 1 | 1 | 1 | 2 <sup>13</sup> /f <sub>XX</sub> (approx. 1.95ms) | ### **CHARACTERISTICS CURVES** Remark: Values in ( ) are processor clock control register (PCC) values. Display Output Current Iop [mA] ### 9.1 PACKAGE OUTLINES ### 64 Pin Plastic Shrink DIP (750 mil) Top view P64C-70-750A,C ### Notes: - Each lead centerline is located within 0.17 mm (0.007 inch) of its true position (T. P.) at maximum material condition. - Item "K" to center of leads when formed parallel. | ITEM | MILLIMETERS | INCHES | |------|----------------------------------------|-------------------------------------------| | Α | 58.68 MAX. | 2.311 MAX. | | В | 1.78 MAX. | 0.070 MAX. | | С | 1.778 (T.P.) | 0.070 (T.P.) | | D | 0.50 <sup>±0.10</sup> | 0.020+0.004 | | F | 0.9 MIN. | 0.035 MIN. | | G | 3.2 <sup>±0.3</sup> | 0.125 <sup>±0.012</sup> | | Н | 0.51 MIN. | 0.020 MIN. | | . 1 | 4.31 MAX. | 0.170 MAX. | | J | 5.08 MAX. | 0.200 MAX. | | K | 19.05 (T.P.) | 0.750 (T.P.) | | L | 17.0 | 0.559 | | М | 0.25 <sup>+0.10</sup> <sub>-0.03</sub> | 0.010 <sup>+0.004</sup> <sub>-0.003</sub> | | N | 0.17 | 0.007 | | ITEM | MILLIMETERS | | |------|-----------------------|--| | Α | 23.6 <sup>±0.4</sup> | | | В | 20 <sup>±0.2</sup> | | | С | 14 <sup>±0.2</sup> | | | D | 17.6 <sup>±0.4</sup> | | | F | 1.0 | | | G | 1.0 | | | Н | 0.40 <sup>±0.10</sup> | | | I | 0.20 | | | J | 1.0 | | | K | 1.8 <sup>±0.2</sup> | | | L | 0.8 <sup>±0.2</sup> | | | М | 0.15+0.10 | | | N | 0.15 | | | Р | 2.7 | | ## CHAPTER 3 µPD75304/306/308/312/316 4 BIT MICROCOMPUTER WITH L.C.D. CONTROLLER/DRIVER ### 1. Overview The µPD75304, 75306, 75308, 75312, and 75316 are a product group in the series of µCOM-75X 4-bit single-chip microcomputers which contains an internal programmable LCD controller/driver and standard NEC serial bus interface, High-speed operation and high-advanced functions are more of their features. Their Products are especially enhanced as the described below, in comparison with the $\mu$ PD7514 which has contained the internal LCD controller/driver in $\mu$ PD7500 series. - ROM capacitance : Maximum 16256 words x 8 bits - RAM capacitance: 512 x 4 bits - General purpose register: Maximum 8 x 4 bits - High-speed operation: Minimum instruction execution time = 1 us - Eight interrupt sources and efficient interrupt service - Efficient instruction system which can handle 1-, 4-, or 8-bit data by each data length - Three-channel multifunction timer - Very low power consumption for clock operation in standby mode (subsystem clock consumes very little power) ### Application Fields - Appliances: VTR's, Audio sets (CD player), etc. - Others : Telephones, Cameras, Tonometers, etc. Remarks: The manual explains the μPD75304, μPD75306, μPD75308, μPD75312, and μPD75316. Unless otherwise noted, the μPD753XX is described as a typical product. Use the manual by replacing the μPD753XX with the μPD75304, μPD75306, μPD75308, μPD75312, or μPD75316, where appropriate. ### 1.1 Features - 41 systematic instructions - Versatile bit manipulation instructions - Efficient 4-bit data manipulation instructions - 8-bit data transfer instructions - GETI instructions convert any 2- or 3-byte instruction into a 1-byte instruction - · High-speed operation Minimum instruction execution time = 0.95 us (f<sub>x</sub> = 4.91 MHz, at 5 V operation) - Variable instruction execution time for low voltage, low current operation - when main system clock is selected: 0.95 us, 1.91 us, 15.3 us/4.19 MHz - when subsystem clock is selected: 122 us/32.768 khz - Program memory capacitance (ROM): - $-\,\mu\text{PD75304}$ :4096 words x 8 bits (Mask ROM) - μPD75306 :6016 words x 8 bits (Mask ROM) - μPD75308 :8064 words x 8 bits (Mask ROM) - $-\mu PD75312$ :12160 words x 8 bits (Mask ROM) - μPD75316 :16256 words x 8 bits (Mask ROM) - · Data memory capacity (RAM): 512 x 4 bits - General purpose registers - Eight registers for 4-bit operations: X, A, B, C, D, E, H, L - Four pairs of registers for 8-bit operations: XA, BC, DE, HL - Accumulators - One-bit accumulator (CY) - 4-bit accumulator (A) - 8-bit accumulator (XA) - 68 I/O lines - 36 LCD drive output pins - 24 segment output dedicated pins - 8 dual function pins used for both segment output and CMOS output - 4 common output pins - 8 input pins - 8 middle-voltage N-channel open drain input/output pins (8 pins for driving an LED directly) - 16 CMOS input/output pins (4 pins for driving an LED directly) - Internal pull-up resistors for 31 I/O pins - 23 pins specified by using software - 8 pins specified by using mask option #### LCD controller/driver - Selection of the number of segments: 24, 28, or 32 (4 or 8 segments can be changed to bit output port.) - Display mode selection: Static 1/2 duty (1/2 bias) 1/3 duty (1/2 bias) 1/3 duty (1/3 bias) 1/4 duty (1/3 bias) - Split resistor for LCD drive voltage supply can be incorporated (mask option). #### 3-channel timers - 8-bit timer/event counter Four-stage clock source Event counting possible - 8-bit basic interval generation Reference time generation (1.95 ms, 7.82 ms, 31.3 ms, 250 ms/4.19 MHz) It is applicable to a watchdog timer. - Watch timer 0.5 s time interval generation Count clock source: A change can be made between main and subsystem clocks Watch rapid feed mode (3.9 ms time interval generation) Buzzer output can be made. (2 kHz) ### · 8-bit serial interface - It provides three modes: - 3-line serial I/O mode - 2-line serial I/O mode - SBI mode - The serial transfer data top can be changed between the least and most significant bits (LSB and MSB). - 16-bit bit sequential buffer (special bit manipulation memory): - Suitable for remote control applications. ### · Clock output function - Timer/event counter output (PTO0): Outputs a square wave of any desired frequency $- \ \text{Clock output (PCL)} \ : \varphi, \ f_\chi/2^3, \ f_\chi/2^4, \ f_\chi 2^6$ - Buzzer output (BUZ): 2 kHz (main system clock 4.19 MHz at operation/subsystem clock 32.7 kHz at operation) ## · Vectored interrupt function - Three external vectored interrupts Both rising and falling edge detection interrupt (INT4) Detection edge programmable interrupt with noise elimination function (INT0) Detection edge programmable interrupt (INT1) - External rising edge detection/parallel port edge detection test input (INT2) - Three internal vectored interrupts: Timer/event counter 0 interrupt (INTT0) Basic interval timer interrupt (INTBT) Serial interface interrupt (INTCSI) - Watch test input (INTW) - Two interal oscillators for system clock genertion - Ceramic or crystel oscillator for main system clock oscillation: 4.194304 MHz Standard - Crystal oscillator for subsystem clock oscillation: 32.768 kHz Standard - · Standby operation - STOP mode: Main system clock oscillation stops. - HALT mode: System clock oscillation continues. (CPU clock oscillation continues.) ## · CMOS ## 1.2 Ordering Information | Ordering code | Package | Internal ROM | |--------------------|---------------------------------|--------------| | μPD75304GF-xxx-3B9 | 80-pin plastic QFP (bent leads) | Mask ROM | | μPD75306GF-xxx-3B9 | 80-pin plastic QFP (bent leads) | Mask ROM | | μPD75308GF-xxx-3B9 | 80-pin plastic QFP (bent leads) | Mask ROM | | μPD75312GF-xxx-3B9 | 80-pin plastic QFP (bent leads) | Mask ROM | | μPD75316GF-xxx-3B9 | 80-pin Plastic QFP (bent leads) | Mask ROM | Remark: xxx shows the code number of the mask ROM and option specification 1.3 List of Family Product Functions | ltem | | μΡΔ75304 | μΡD75306 | µРD75308 | μРD75Р308 | μPD75312 | μΡD75316 | µPD75P316 | |-------------------------------------------|---------------------------|----------------------------------------------|------------------------------------------------|------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------| | Program memory | ory | • Mask ROM<br>• 000H-FFFH<br>• 4096 x 8 bits | • Mask ROM<br>• 0000H-177FH<br>• 6016 x 8 bits | • Mask ROM<br>• 0000H-1F7FH<br>• 8064 x 8 bits | • EPROM/one-<br>time PROM<br>• 0000H-1F7FH<br>• 8064 x 8 bits | • Mask ROM • Mask ROM • One-time PROM • 0000H-2F7FHH • 0000H-3F7FHH • 0000H-3F7FHH • 16256 x 8 bits | • Mask ROM<br>• 0000H-3F7FHH<br>• 16256 x 8 bits | • One-time<br>PROM<br>• 0000H-3F7FH | | Data memory | | | | | 512 x 4 bits<br>Bank 0:256 x 4<br>Bank 1:256 x 4 | | | | | Instruction 3- | 3-byte branch instruction | Not included | | | Included | pep | | | | δ | Others | | | | Common to the products | cts | | | | Program counter | er | 12 bits | | 13 bits | | | 14 bits | | | Pull-up resistor<br>(Mask option) | Ports 4 | | Mask option | | Not contained | Mask option | ption | Not contained | | Split resistor for LCD drive power supply | or LCD<br>pply | | Mask option | | Not included | Mask option | ption | Not included | | Pin connection | | №р, РВ( | √ьр, РROM program pins not included | not included | VPP PROM program pins included | VPR PROM program pins<br>not included | suid mi | VPP PROM program pins included | | V <sub>DD</sub> range | | | 2.7-6.0 V | | 2∨±5% | 2.7-6.0 V | | 5∨±5% | | Package | | | 80-pin plastic QFP | | 80-pin ceramic<br>LCC (with window) 80-pin plastic<br>QFP | | 80-pin plastic QFP | | \*: The bit length varies depending on the product type ### 1.5 Pin Connection (Top view) $<sup>^*</sup>$ When using OTP $\mu$ PD75P3XX in the same socket, please note that this is $V_{pP}$ and has to be connected to $V_{DD}$ in operating mode. ### 2. PIN FUNCTIONS ### 2.1 Input and output ports 2.1.1 P00-P03 (port 0) - Input Pins also Used for INT4, SCK, SO/SB0, SI/SB1 P10-P13 (port 1) - Input Pins also Used for INT0, INT1, INT2, and TI0 P00-P03 and P10-P13 are pins for 4-bit input port (port 0 and 1). (1) The P00-P03 pins are also used for the INT4 pin (vectored interrupt input) and the SCK, SO/SB0, and SI/SB1 pin (serial interface output). (2) The P10-P13 pins are also used for the INT0 and INT1 pins (vectored interrupt input), the INT2 pin (edge detection test input) and the TI0 pin (external event pulse to the timer/event counter). The state of each pin P00-P03 and P10-P13 can always be input regardless of the condition of any of the pins INT4, SCK, SO/SB0, SI/SB1, INT0, INT1, INT2, and TI0. To prevent noise from causing a malfunction, a Schmitt trigger input is applied to port 0 P00/INT4, P01/SCK, P02/SO/SB0, P03/SI/SB1 input and port 1 pins. In addition, P10 is provided with a noise removal circuit. (For details, see 6.3 (2).) An internal pull-up resistor can be specified for port 0 in 3-bit units (P01-P03) and for port 1 in 4-bit units (P10-P13) by using the software-operated pull-up resistor specification register group A. When the RESET signal is generated, every pin is placed in input port mode. 2.1.2 P20-P23 (port 2) - Input/Output Pins also Used for PTO0, PCL, and BUZ P30-P33 (port 3) - Input/Output Pins also Used for LCDCL and SYNC. P40-P43 (port 4) - and P50-53 (port 5) - N-Channel Open Drain Medium-Voltage (10 V) P60-P63 (port 6), P70-73 (port 7) - 3-State Input/Output P20-P23, P30-P33, P40-P43, P50-P53, P60-P63, and P70-P73 are 4-bit input/output ports with output latches. - (1) The P20-P23 pins are also used for the PTO0 pin timer/event counter output), the PCL pin (programmable clock output), and the BUZ pin (fixed frequency output). - (2) The P30-P33 pins are also used for the LCDCL pin (LCD external extended driver driving clock) and the SYNC pin (LCD) external extended driver synchronizing clock). - (3) The P60-P63 and P70-P73 pins are also used for the KR0-KR3 and KR4-KR7 pins (key interrupt input). Port 3 has high-current output, enabling an LED to be driven directly. Ports 4 and 5 outputs are N-channel open drain medium-voltage (10 V) and high-current, enabling an LED to be driven directly. The input/output mode of each port is selected by using the port mode register. The mode of port 2, 4, 5, or 7 can be specified in 4-bit units, and that of port 3 or 6 bitwise. An internal pull-up resistor can be specified for ports 2, 3, 6, and 7 in 4-bit units by using software to operate the pullup resistor specification register (POGA). It can be specified for ports 4 and 5 bitwise by using the mask option. Ports 4 and 5 (6 and 7) can be paired for input/output in 8-bit units. When the RESET signal is generated, ports 2, 3, 6, and 7 are placed in input mode (output high impendance) and ports 4 and 5 are set to a high level (when internal pull-up register is contained) or to high impendance. ### 2.1.3 BP0-BP7 - Output Pins also Used for S24-S31 (LCD Controller/Driver Segment Signal Output) BP0-BP7 are bit port 0-7 output pins (each port is a 1-bit output port with output latch). The BP0-BP7 pins are also used for the S24-S31 pins (LCD controller/driver segment output signal output pins). ### 2.1.4 TI0 - Input Pin also Used for Port 1 TIO is an external event pulse input pin for the programmable timer/event counter. The pin is Schmitt trigger input. ### 2.1.5 PTO0 - Output Pin also Used for Port 2 PTO0 is a programmable timer/event counter output pin which outputs square wave pulses. To output a programmable timer/event counter signal, the P20 output latch is cleared and the port 2 bit of the port mode register is set to 1 (output mode). Output is cleared by execution of the timer start instruction. ### 2.1.6 PCL - Output Pin also Used for Port 2 PCL is a programmable clock output pin used to supply clocks to peripheral LSI devices such as a slave microcomputer and an A/D converter. When the RESET signal is generated, the clock mode register (CLOM) is cleared, clock output is inhibited, and the normal port operation mode is set. 2.1.7 BUZ - Output Pin also Used for Port 2 BUZ is a fixed frequency output pin. Fixed frequency (2.048 kHz) output is used for buzzer sounding and system clock oscillation frequency trimming. The BUZ pin, also used for the P23 pin, is validated only when bit 7 (WM7) of the watch mode register (WM) is set to 1. When the RESET signal is generated, WM7 is cleared and the normal port operation mode is set. ### 2.1.8 SCK, SO/SB0, and SI/SB1 - 3-State Input/Output Pins also Used for Port 0 SCK, SO/SB0, and SI/SB1 are input/output pins for serial interface and operate according to how the serial operation mode register (CSIM) is set. When the RESET signal is generated, serial interface operation is stopped and the pins are used for port 0 (input port). Every pin is Schmitt trigger input. ### 2.1.9 INT4 - Input Pin also Used for Port 0. INT4 is an external vectored interrupt input pin (both rising and falling edged active). When the signal input to the pin changes from low to high state or from high to low state, the interrupt request flag is set. INT4 is for asynchronous input. When a signal having a given high or low level duration is input, it is acknowledged independently of the CPU operation clock. INT4 can also be used to release the STOP or HALT mode. It is Schmitt trigger input. ### 2.1.10 INT0 and INT1 - Input Pins also Used for Port 1 INTO and INT1 are edge detection vectored interrupt input pins. INT0 has the noise removal function. Detected edge selection can be made using edge detection mode registers (IM0 and IM1). - (1) INT0 (IM0 bits 0 and 1) - (a) Rising edge active - (b) Falling edge active - (c) Both rising and falling edges active - (d) External interrupt signal input inhibited - (2) INT1 (IM1 bit 0) - (a) Rising edge active - (b) Falling edge active INTO has the noise removal function; sampling clocks for noise removal can be changed two stages. The acknowledged signal width varies depending on CPU clock operation. INT1 is for asynchronous input. When a signal having a given high level duration is input, it is acknowledged independently of the CPU clock operation. When the RESET signal is generated, IM0 and IM1 are cleared and rising edge active is selected. INTO and INT1 are Schmitt trigger inputs. ## 2.1.11 INT2 - Input Pin also Used for Port 1 INT2 is an external test input pin (both rising and falling edges active). When INT2 is selected by using the edge detection mode register (IM2) and the signal input to the INT2 pin transits from low to high state, the internal test flag (IRQ2) is set. INT2 is for asynchronous input. When a signal having a given high level duration is input, it is acknowledged independently of the CPU clock operation. When the RESET signal is generated, IM2 is cleared and the test flag (IRQ2) is set by inputting the rising edge to the INT2 pin. ## 2.1.12 KR0-KR3 - Input Pins also Used for Port 6 KR4-KR7 - Input Pins also Used for Port 7 KR0-KR7 are key interrupt (parallel falling edge detection interrupt) input pins. The interrupt format can be specified by setting the edge detection mode register (IM2). When the RESET signal is generated, the pins are placed in port 6 and 7 input mode. #### 2.1.13 S0-S23 - Output S24-S31 - Output Pins also Used for Bit Ports 0-7 S0-S31 are segment signal output pins for directly driving LCD segments (front electrodes). Static, 2 or 3 time division (1/2 bias law), or 3 or 4 time division (1/3 bias law) driving is performed. S0-S23 are segment-only output pins. S24-S31 are also used for the bit port 0-7 output; which mode the pins are used for, is specified by using the dislay mode register (LCDM). ### 2.1.14 COM0-COM3 - Output COM0-COM3 are common signal output pins for directly driving the LCD common pins (rear electrodes). Common signals are output when static (COM0, COM1, COM2, COM3 output), while driving by 1/2 bias law 2 time division (COM0, COM1 output), while driving by 3 time division (COM0, COM1, COM2 output), while driving by 1/3 bias law 3 time division (COM0, COM1, COM2, COM3 output) is performed. ## 2.1.15 V<sub>LC0</sub>-V<sub>LC2</sub> $V_{LCO}^{-}$ V<sub>LC2</sub> are power supply pins to drive the LCD. The $\mu$ PD753XX allows split-resistor incorporation in the $V_{LCO}^{-}$ v<sub>LC2</sub> pins so that LCD drive power can be supplied according to the bias law without using an external split resistor. (Mask option) ### 2.1.16 BIAS BIAS is an LCD power supply bias control pin. To deal with various LCD drive voltages, the BIAS pin is connected to the $V_{LC0}$ pin to change the resistor split ratio. By connecting an external resistor, the BIAS pin can be used together with the $V_{LC0}$ - $V_{LC2}$ and $V_{SS}$ pins for fine adjustment of the LCD drive supply voltage. #### 2.1.17 LCDCL LCDCL is a clock output pin for driving an external LCD extension driver. #### 2.1.18 SYNC SYNC is a clock output pin for synchronizing an external LCD extension driver. #### 2.1.19 X1 and X2 X1 and X2 are connection pins for the main system clock crystal / ceramic oscillator. External clocks can also be input. ## 2.1.20 XT1 and XT2 XT1 and XT2 are crystal connection pins for the subsystem clock oscillation. External clocks can also be input. ## 2.1.21 RESET RESET is an active low reset input pin. RESET is for asynchronous input. When a signal having a given low level duration is input independently of the operation clock, the RESET signal is generated and the system is reset overriding all other operations. It is used for normal CPU initialization / start-up and also to release the standby (STOP or HALT) mode. RESET is a Schnitt trigger input. 2.1.22 $\rm\,V_{DD}$ $\rm\,V_{DD}$ is a positive power supply pin. 2.1.23 $V_{SS}$ V is a ground potential. ## 2.2 Pin Function List (1) Normal operation mode Table 2.2-1 Digital Input / Output Port Pin Function List | Pin name | 1/0 | Also<br>used for: | Fur | nction | 8-bit<br>I/O | When reset | I/O circuit<br>type (Note 1) | |---------------------|-----|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------|-----------------------------------------------------------------------------------|------------------------------| | P00 | 1 | INT4 | 4-bit input port (p | oo# 0) | | | B | | P01 | I/O | SCK | Internal pull-up r | esistors | × | Input | (F)- A | | P02 | 1/0 | SO/SB0 | can be specified in 3-bit units by u | | ^ | input | (F)– В | | P03 | 1/0 | SI/SB1 | in 5-bit dring by t | ising software | | | M-c | | P10 | | INT0 | | With noise removal function | | | - | | P11 | 1 | INT1 | 4-bit input port (p | port 1). | × | Input | (B)- C | | P12 | ] ' | INT2 | Internal pull-up re | | _ ^ | | | | P13 | | TIO | in 4-bit units by u | | | | | | P20 | | PTO0 | 4-bit input/output | t port (port 2) | | | | | P21 | | - | Internal pull-up r | esistor can be | × | Input | E-B | | P22 | 1/0 | PCL | specified for P20<br>units by using so | | 1 ^ | Input | C - D | | P23 | | BUZ | dinis by using so | niwaic. | | | | | P30 | | LCDCL | Programmable 4 | | | | | | P31 | | SYNC | port (port 3). Input or output mode can be selected bitwise. Internal pull-up resistor can be | | | | | | P32 | 1/0 | _ | | | х | Input | E – B | | P33 | | - | specified for P30 units by using so | | | | ist<br>Policy | | P40-P43<br>(Note 2) | I/O | - | N-channel open drain 4-bit input/output port (port 4). Pull-up resistor can be incorporated bitwise (mask option). 10 Volts during open drain. | | o | High level (when<br>pull-up resistor<br>is incorporated)<br>or high<br>impendance | М | | P50-P53<br>(Note 2) | 1/0 | - <del>-</del> - | N-channel open input/output port Pull-up resistor cincorporated bitwoption). 10 Volts during o | (port 4).<br>an be<br>vise (mask | | High level (when pull-up resistor is incorporated) or high impendance | М | (to be continued) Table 2.2-1 Digital Input / Output Port Pin Function List (cont'd) | Pin name | 1/0 | Also<br>used for | Function | 8-bit<br>I/O | When reset | I/O circuit<br>type (Note 1) | |----------|-----|------------------|---------------------------------------------------------------------|--------------|------------|------------------------------| | P60 | | KR0 | Programmable 4-bit input/output port (port 6). Input or output mode | 4 | | | | P61 | | KR1 | can be selected bitwise. | | lan.a | | | P62 | 1/0 | KR2 | Internal pull-up resistor can be | | Input | (F)- A | | P63 | | KR3 | specified for P60-P63 in 4-bit units by using software. | 0 | | | | P70 | | KR4 | 4-bit input/output port (port 7). | | | | | P71 | 1/0 | KR5 | Internal pull-up resistor can be | | Input | (F)- A | | P72 | 1// | KR6 | specified for P70-P73 in 4-bit units by using software. | | при | "-^ | | P73 | | KR7 | units by using software. | | | | | BP0 | | S24 | | | | | | BP1 | | S25 | | | | | | BP2 | 0 | S26 | | | | | | BP3 | | S27 | 1-bit output ports (bit ports). x The pins are also used for the | × | Note 3 | G-C | | BP4 | | S28 | segment output pins. | ^ | 14016-0 | | | BP5 | 0 | S29 | | | | | | BP6 | | S30 | | | | | | BP7 | | S31 | | | | | Note 1: The $\bigcirc$ mark denotes Schmitt trigger input Note 2: LED can be driven directly Note 3: BP0-7 select $V_{LC1}$ as the input source. The output level is changed by the external circuit of BP0-7 and V<sub>LC1</sub>. Example: Since BP0-BP7 are connected to each other through the µPD753XX as illustrated below, the BP0-BP7 output level is determined by the resistance value of R1, R2, R3. Table 2.2-2 Pin Function List other than Port Pins | Pin name | I/O | Also<br>used for: | Function | | When reset | I/O circuit<br>type (Note 1) | |------------------------------------|-----|-------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------|--------------|------------------------------| | TIO | 1 | P13 | External event pulse input pin to time | r / event counter. | | <b>B</b> −c | | PT00 | I/O | P20 | Timer / event counter output pin. | 1 | Input | E-B | | PCL | 1/0 | P22 | Clock output pin. | | Input | E – B | | BUZ | I/O | P23 | Fixed frequency output pin (for buzze trimming). | er or system clock | Input | E-B | | SCK | 1/0 | P01 | Serial clock input / output pin. | | Input | (F)- A | | SO/SB0 | I/O | P02 | Serial data output pin.<br>Serial bus input / output pin. | | Input | <b>(</b> Б– в | | SI/SB1 | I/O | P03 | Serial data input pin.<br>Serial bus input / output pin. | | Input | <b>∭</b> -c | | INT4 | 1 | P00 | Edge detection vectored interrupt inp of both rising and falling edges is acti | | | B | | INT0 | ı | P10 | Edge detection vectored interrupt input pin (detected edge can be | Synchronous clock | | <b>B</b> -c | | INT1 | | P11 | selected). | | | | | INT2 | 1 | P12 | Edge detection testable input pin asy edge is detected). | nchronous (rising | | (B-c | | KR0-KR3 | I/O | P60-P63 | Parallel falling edge detection testable pins. | e input | Input | (F)- A | | KR4-KR7 | I/O | P70-P73 | Parallel falling edge detection testable pins. | e input | Input | <b>(F)</b> – A | | S0-S23 | 0 | - | Segment signal output pins. | Note 4 | G-A | | | S24-S31 | 0 | BP0-7 | Segment signal output pins. | Note 4 | G-C | | | сомо-сомз | 0 | - <u>-</u> | Common signal output pins. | Note 4 | G-B | | | V <sub>LC0</sub> -V <sub>LC2</sub> | - | - | LCD drive power supply pins. Interna be used (mask option). | _ | <del>-</del> | | | BIAS | 0 | - | Output pin to cut external split resisto | or. | Note 5 | | | LCDCL<br>(Note 3) | 1/0 | P30 | Clock output pin for external extension | on driver. | Input | E – B | | SYNC<br>(Note 3) | I/O | P31 | Clock output pin for synchronizing ex driver. | ternal extension | Input | E – B | | X1, X2 | | | Connection pins for main system cloc<br>oscillator. When external clock is use<br>and its opposite phase is input to X2. | -<br>-<br>- | _ | | | XT1 | I | | Subsystem clock oscillation crystal co<br>When external clock is used, it is input | ut to XT1, and | _ | _ | | XT2 | _ | | XT2 is not connected. XT1 can be us (test) pin. | ed for 1-bit input | . – | - | | RESET | 1 | | System reset input pin. | | _ | B | | NC<br>(Note 2) | - | | No connection | | _ | - | | V <sub>DD</sub> | _ | | Positive power supply pin. | | _ | - | | V <sub>ss</sub> | _ | | Ground potential pin. | | - | - | #### Notes: - The mark denotes Schmitt trigger input. - Connected the NC pin to V<sub>DD</sub>, when μPD75P308 and printed board are also shared with. The pins are provided for future system expansion; at present they are used only for the P30 and P31 pins - 4. For each display output, the following $V_{\text{LCX}}$ are selected as input sources: S0-31 COM0-COM2 : V<sub>LC2</sub> СОМЗ : V<sub>LC0</sub> However, the display output level varies depending on the display output and V<sub>i cx</sub> external circuit. Since BP0-BP7 are connected to each other through the µPD753XX as illustrated below, the BP0-BP7 output level is determined by the resistance value of R1, R2, R3. 5. When internal split resistor is contained : Low level When internal split resistor is not contained: High impedance ## 2.3 Pin Input / Output Circuits The µPD753XX pin input / output circuits are shown in schematic drawings. (1) Type A (for Type E - B) CMOS standard input buffer (2) Type B Schmitt trigger input with hysteresis characteristic (3) Type B - C (4) Type D (for Type E - B, F - A) Push-pull output where output can be placed in high impedance (both P and N channels are turned off). (5) Type E - B P.U.R.: Pull-Up Resistor (6) Type F - A P.U.R.: Pull-Up Resistor (7) Type F - B P.U.R.: Pull-Up Resistor # (8) Type G - A # (9) Type G - B (10) Type G - C (11) Type M P.U.R.: Pull-Up Resistor P.U.R.: Pull-Up Resistor ## 2.4 Processing of Unused Pins ## Table 2.4-1 Unused Pins Lists | Pin | Recommended connection | | | | | | |------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | P00 / INT4 | Connect to V <sub>SS</sub> . | | | | | | | P01 / SCK | | | | | | | | P02 / SO /SB0 | Connect to V <sub>SS</sub> or V <sub>DD</sub> . | | | | | | | P03 / SI / SB1 | | | | | | | | P10 / INTO-P12 / INT2 | Connect to V | | | | | | | P13 / TI0 | Connect to V <sub>SS</sub> . | | | | | | | P20 / PTO0 | and the second of o | | | | | | | P21 | | | | | | | | P22 / PCL | | | | | | | | P23 / BUZ | | | | | | | | P30-P33 | Input mode: Connect to V <sub>SS</sub> or V <sub>DD</sub> . Output mode: Do not connect. | | | | | | | P40-P43 | Salpar moder be not connect. | | | | | | | P50-P53 | | | | | | | | P60-P63 | | | | | | | | P70-P73 | · | | | | | | | S0-S23 | | | | | | | | S24 / BP0-S31 / BP7 | Do not connect. | | | | | | | СОМ0-СОМ3 | | | | | | | | V <sub>LC0</sub> -V <sub>LC3</sub> | Connect to V <sub>SS</sub> . | | | | | | | BIAS | Only when all of V <sub>LC2</sub> –V <sub>LC2</sub> are unused, connect BIAS to V <sub>SS</sub> ; otherwise, do not connect. | | | | | | | XT1 | Connect XT1 to V <sub>SS</sub> or V <sub>DD</sub> . | | | | | | | XT2 | Do not connect XT2. | | | | | | ## 2.5 Mask Option Selection The pins contain the mask option function as listed in Table 2.5-1. However, mask option is not contained in the $\mu PD75P308$ or $\mu PD75P316$ . Table 2.5-1 Mask option selection | Pin names | Mask option | |-------------------------------------------|-----------------------------------------------------------------------------------------------| | P40–P43,<br>P50–P53 | . Pull-up resistor is included.<br>specified bit-wise.<br>. Pull-up resistor is not included. | | Split resistor for LCD drive power supply | . Split resistor is included.<br>. Split resistor is not included. | ### 3. ARCHITECTURE AND MEMORY MAP The μCOM-75X architecture for the μPD753XX adopts data memory bank configuration and memory mapped I / O to provide features such as: - Internal RAM with maximum of 4K words x four bits (12-bit addresses) - Peripheral hardware extensibility This chapter covers these topics. ## 3.1 Data Memory Bank Configuration and Addressing Modes ### 3.1.1 Data memory bank configuration A general purpose static RAM (480 words x four bits) is incorporated in data memory space addresses 000H to 1DFH, and display data memory (32 words x four bits) is incorporated in adresses 1E0H to 1FFH. Peripheral hardware such as input/output ports and timers is allocated to addresses F80H to FFFH. To address the data memory space (4K words x four bits) with 12-bit addresses, the $\mu$ PD753XX adopts a memory bank configuration where the low-order eight bits of an address are specified either directly or indirectly by using an instruction, and the high-order four bits of an address are specified by using a memory bank. To specify the memory bank (MB), two hardware devices are incorporated in the μPD753XX: - Memory bank enable flag (MBE) - Memory bank selection register (MBS) MBS is a register used to select a memory bank. The µPD753XX allows 0, 1, or 15 to be set in MBS. MBE is a flag used to determine whether or not the memory bank selected by using MBS is validated. As shown in Fig. 3.1–1, when MBE is set to 0, the specified memory bank is fixed regardless of how MBS is set; when MBE is set to 1, memory bank switching can be performed to extend data memory space by setting MBS. In data memory space addressing, normally MBE is set to 1, and the data memory area of the memory bank specified by using MBS is handled. An efficient program can be prepared by using MBE = 0 mode and MBE = 1 mode appropriately in each process of the program. | | Applicable program processing | Effects | |--------------|------------------------------------------------------------------------------------------------|--------------------------------------------| | | ° Interrupt service | MBS save and restore are made unnecessary. | | MBE = 0 mode | ° Repetitive processing of internal<br>hardware operation and general<br>purpose RAM operation | MBS change is made unecessary. | | | ° Subroutine processing | MBS save and restore are made unnecessary. | | MBE = 1 mode | ° Normal program processing | | Figure 3.1-1: Proper Use of MBE = 0 and MBE = 1 Modes MBE is saved or restored automatically during subroutine processing and can be changed as desired. When interrupt service is made, MBE is automatically saved or restored. MBE during interrupt service can also be specified at the same time interrupt service starts by setting the interrupt vector table. Thus, it is useful for high-speed interrupt service. To change the MBS setting in subroutine processing or interrupt service, MBS is saved and restored by using PUSH and POP instructions. MBE is set and reset by using SET1 and CLR1 instructions. MBS is set by using the SEL instruction. Example 1: To clear MBE and fix memory bank CLR1 MBE; MBE ◆ 0 Example 2: To select memory bank 1 SET1 MBE ; MBE ◆ 1 SEL MB1 ; MBS ←1 ## 3.1.2 Data memory addressing modes The $\mu$ COM-75X architecture adopted for the $\mu$ PD753XX provides seven addressing modes, as shown in Fig. 3.1–2, for efficiently addressing the data memory space for each bit length of data to be processed. #### (1) 1-bit direct adressing (mem. bit) This addressing mode directly specifies each bit in all the data memory space by using the instruction operand. When MBE is set to 0, the specified memory bank (MB) is fixed to memory bank 0 (MB0) if the address specified in the operand is 00H-7FH; it is fixed to memory bank 15 (MB15) if the address specified in the operand is 80H-FFH. Thus, when MBE is set to 0, both the general purpose RAM area (000H-07FH) and peripheral hardware area (F80H-FFFH) can be addressed. When MBE is set to 1, any memory bank can be specified by setting MBS; data memory space that can be specified can be extended. The 1-bit direct addressing mode is applicable to bit set and reset instructions (SET1 and CLR1) and bit test instructions (SKT and SKF). Example: To set FLAG1, reset FLAG2, and test whether or not FLAG3 is set to 0. FLAG1 EQU 03FH. 1 ; 3FH address bit 1 FLAG2 EQU 087H. 2 ; 87H address bit 2 FLAG3 EQU 0A7H. 0 ; A7H address bit 0 SET1 MBE ; MBE ← 1 SEL MB0 ; MBS ← 0 SET1 FLAG1 ; FLAG1 ← 1 CLR1 FLAG2 ; FLAG2 ← 0 SKF FLAG3 ; FLAG3 = 0 ? Figure 3.1-2 Data Memory Configuration and Addressing Range of each Addressing Mode | Addressing mode | Representation format | Specified address | | | |---------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 1-bit direct addressing | mem. bit | Bit indicated by a bit at the address indicated by MB and mem. However, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FFH When MBE = 1, MB = MBS | | | | 4-bit direct addressing | | Address indicated by MB and mem. However, MBE = 0, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FH When MBE = 1, MB = MBS | | | | 8-bit direct addressing | mem | Address indicated by MB and mem (mem is an even address). However, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FFH When MBE = 1, MB = MBS | | | | | @ HL | Address indicated by MB and HL. However, MB = MBE • MBS | | | | 4-bit register<br>indirect addressing | @ DE | Memory bank 0 address indicated by DE | | | | | @ DL | Memory bank 0 address indicated by DL | | | | 8-bit register indirect addressing | @ HL | Address indicated by MB and HL (the L register contains an even number). However, MB = MBE • MBS | | | | | fmem. bit | Bit indicated by a bit at the address indicated by fmem. However, fmem { FB0H-FBFH (hardware related to interrupt) FF0H-FFFH (I/O port) | | | | Bit manipulation addressing | pmem. @ L | Bit indicated by the low-order two bits of the L registered the address indicated by the high-order 10 bits of pmem and the high-order two bits of the L register. However, pmem = FC0H-FFFH | | | | | @ H + mem. bit | Bit indicated by a bit at the address indicated by MB, H, and the low-order four bits of mem. However, MB = MBE • MBS | | | | Stack addressing | | Memory bank 0 address indicated by SP. | | | Figure 3.1-3 Addressing Modes ### (2) 4-bit direct addressing (mem) This addressing mode directly specifies all the data memory space in 4-bit units by using the instruction operand. As with the 1-bit direct addressing mode, when MBE is set to 0, the 4-bit direct address mode allows that only the general purpose RAM area (000H-07FH) and peripherial hardware area (F80H-FFFH) can be specified. When MBE is set to 1, any memory bank (MB) can be specified by setting MBS and the data memory space that can be specified is extended to all the The 4-bit direct addressing mode is applicable to the MOV, XCH, INCS, IN, and OUT instructions. Example 1: To input port 4 and store in "DATA1". DATA1 EQU 5FH "DATA1" is address 5HF. CLR<sub>1</sub> MBE MBE<del></del> 0 IN A. PORT4 A<del>←</del> PORT4 MOV DATA1, A (DATA1) <del>→</del> A Example 2: To output data in "BUFF" to port 5. BUFF FOU 11AH "BUFF" is address 11AH > SET1 MBE MBE<del>◀</del> 1 SEL MB<sub>1</sub> MBS<del><</del> 1 MOV A, BUFF A<del><−</del> (BUFF) SEL MBS<del><--</del> 15 MB15 OUT PORT5<del></del> → A PORT5, A ### Caution: If data related to the input /output ports is stored in general purpose RAM of bank 1 as in this example, the program is made less efficient. If data related to the input /output ports is stored in addresses 00H-7FH of bank 0, a program can be prepared without changing MBS as in Example 1. ## (3) 8-bit direct addressing (mem) This addressing mode directly specifies all the data memory space in 8 bit units by using the instruction operand. Only even address can be specified in the mem operand. The 4-bit data at the address specified in the operand and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register pair) for 8-bit processing. The memory banks specified in the addressing mode are the same as in the 4-bit direct addressing mode. The 8-bit direct addressing mode is applicable to the MOV, XCH, IN, and OUT instructions. Example 1: To transfer 8-bit data in ports 4 and 5 to addresses 20H and 21H. DATA EQU 020H > CLR<sub>1</sub> MBF MBF <del>←</del> 0 XA, PORT4; X → port 5, A → port 4 IN MOV DATA, XA Example 2: To read 8-bit data input to the serial interface shift register (SIO), set transfer data, and start of transfer. SEL MB15 MBS <del> 1</del> 15 XCH XA. SIO XA (SIO) ## (4) 4-bit register indirect addressing (@rpa) This addressing mode indirectly specifies the data memory space in 4-bit units by using the data pointer (general purpose register pair) specified in the instruction operand. The data pointers are the HL register pair, which enables all the data memory space to be specified according to MB = MBE • MBS specification, and the DE and DL register pairs, which always indicate memory bank 0 regardless of how MBE and MBS are set. Efficient programs can be prepared by using the data memory bank to be used. Example: To transfer data at 50H-57H to 110H-117H. ``` DATA1 EQU 57H DATA2 EQU 117H SET1 MBE SEL MB<sub>1</sub> MOV D. #DATA1 SHR 4 MOV HL, #DATA2 AND 0FFH; HL 17H LOOP: MOV A, @DL ; A<del> </del> (DL) ; A ← (HL) XCH A, @HL DECS L BR LOOP ``` The addressing mode using the HL register pair for the data pointer has wide applications such as data transfer, operation, comparison, and input / output. The addressing mode using the DE or DL register pair is applicable to the MOV and XCH instructions. As shown in Fig. 3.1–4, data memory space addresses can be updated as desired by combining the addressing mode with general purpose register (or register pair) increment and decrement instructions. Example 1: To compare data at 50H-57H with data at 110H-117H. ``` DATA1 EQU 57H DATA2 EQU 117H SET1 MBE SEL MB1 MOV D, #DATA1 SHR 4 MOV HL, #DATA2 AND 0FFH LOOP: MOV A, @DL SKF A, @HL A = (HL)? BR NO NO DECS YES, L← L-1 BR LOOP ``` Example 2: To clear data memory area 04H-FFH. ``` SEL MBF MOV XA, #00H MOV L, #04H LOOP: MOV @HL, A (HL)← A INCS L ← L+1 L BR LOOP INCS Н H<del><−</del> H+1 BR LOOP ``` Figure 3.1-4 General Purpose RAM Address Update Method ## (5) 8-bit register indirect addressing (@HL) This addressing mode indirectly specifies all the data memory space in 8-bit units by using the data pointer (HL register pair). The 4-bit data at the address setting data pointer bit 0 (L register bit 0) to 0 and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register) for 8-bit processing. The memory banks specified in the addressing mode are the same as those when the HL register is specified in the 4-bit register indirect addressing mode (MB = MBE • MBS). The 8-bit register indirect addressing mode is applicable to the MOV, XCH, and SKE Instructions. Example 1: To compare the count register (T0) value of timer/event counter 0 with data at addresses 30H and 31H for equality. ``` DATA EQU 30H CLR<sub>1</sub> MBE MOV HL, #DATA MOV XA, TO XA ← count register 0 SKF A = (HL)? A. @HL BR NO INCS MOV A. X A← X SKE A = (HL)? A, @HL ``` ## (6) Bit manipulation addressing This addressing mode is used to perform bit manipulations such as Boolean operation or bit transfer on any bit in all of the data memory space. Although the 1-bit direct addressing mode is applicable only to the bit set, reset, and test instructions, the bit manipulation addressing mode enables bit manipulations such as Boolean operations by using the AND1, OR1, and XOR1 instructions and allows bit test and bit reset by using the SKTCLR instructions. The following three types of bit manipulation addressing modes can be used according to the data memory address to be used: (a) Specific address bit direct addressing (fmem. bit). This addressing mode enables, peripheral hardware that frequently uses bit manipulation, such as input/output ports and interrupt flags, to be operated at any time independently of the memory bank setting. Thus, the addressing mode is applicable to data memory addresses FF0H-FFFH (where input/output ports are mapped) and FB0H-FBFH (where hardware related to interrupts is mapped). For the hardware of the two data memory areas, bit manipulation can be performed in direct addressing at any time as desired regardless of how MBS and MBE are set. Example 1: To test the timer 0 interrupt request flag (IRQT0); if the request flag is set, clear the flag and reset P63. Example 2: To reset P53 if both P30 and P41 are set to 1. - (i) SET1 CY CY <del><−</del> 1 AND1 CY, PORT3.0 CY P3.0 AND<sub>1</sub> CY, PORT4.1 CY P4.1 SKT CY CY = 1? BR SETP CLR<sub>1</sub> PORT5.3 P53 - 1 SETP: SET1 PORT5.3 P53 - 1 PORT3.0 (ii) SKT P30 = 1 ?BR SETP SKT PORT4.1 P41 = 1? BR **SETP** CLR<sub>1</sub> PORT5.3 P53 ← 0 STEP: SET1 PORT5.3 P53 <del>←</del> 1 - (b) Specific address bit register indirect addressing (pmem. @L). This addressing mode indirectly specifies each bit of peripheral hardware, such as an input / output port, by using the L register for successive operation. The addressing mode is applicable to data memory addresses FC0H-FFFH. The addressing mode directly specifies the high-order 10 bits of a 12-bit data memory address in the pmem operand and indirectly specifies the low-order 2-bit data memory address part and the bit address by using the L register. Thus, 16 bits (four ports) can be manipulated (operated) successively by L register specification. The address mode also enable bit manipulation to be performed at any time independently of how MBE and MBS are set. Example: To output a pulse to each bit of ports 4 to 7 in order. (c) Special 1-bit direct addressing (@H + mem. bit) This addressing mode enables bit manipulation to be performed on any bit in all of the data memory space. The addressing mode indirectly specifies the high-order four bits of data memory address of the memory bank specified by MB = MBE MBS by using the H register and directly specifies the low-order 4-bit data memory address part and the bit address in the operands. It enable various types of bit manipulation to be performed on any bit in all of the data memory space. Example: To reset address 32H bit 2 (FLAG3) if both address 30H bit 3 (FLAG1) and address 31H bit 0 (FLAG2) are set to 0 or 1. ``` FLAG1 EQU 30H.3 FLAG2 EQU 31H.0 FLAG3 EQU 32H 2 SEL MB0 MOV H, #FLAG1 SHR 6 CLR1 OR1 CY. @H + FLAG1 XOR1 CY, @H + FLAG2 CY-FLAG1 CY-FLAG2 SET1 @H + FLAG3 SKT CY CY = 1? CLR1 FLAG<del>←</del> 30 @H + FLAG3 ``` ### (7) Stack addressing The stack addressing mode is used for register save and restore during interrupt service or subroutine processing. The processing mode specifies an address by using the 8-bit stack pointer (data memory bank 0). The addressing mode can also be used for register save and restore by executing the PUSH and POP instructions. Example 1: To save and restore register in subroutine processing. Example 2: To transfer the HL register pair contents to the DE register pair. PUSH HL POP DE ; DE → HL Example 3: To branch to the address indicated by [XABC] register. PUSH BC PUSH XA RET ; Branch to XABC address ### 3.2 Memory Mapped I / O The μPD753XX adopts memory mapped I/O where peripheral hardware such as input/ports and timers is allocated to addresses F80H-FFFH of the data memory space as shown in Fig. 3.1–2. Thus, peripheral hardware is controlled entirely by memory operation instructions rather than special instructions. (To easily understand programs, some hardware control mnemonics are provided.) Table 3.2-1 lists the addressing modes that can be used to operate peripheral hardware. Memory bank 1 is specified to operate the display data memory mapped in addresses 1E0H-1FFH. Table 3.2-1 Applicable Addressing Modes during Peripheral Hardware Operation | | Applicable addressing mode | Applicable hardware | | | |---------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--|--| | | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem. bit). | All hardware where bit manipulation can be performed. | | | | Bit<br>manipulation | Direct addressing regardless of how MBE and MBS are set. (specification in fmem. bit) | ISTO, MBE<br>IExxx, IRQxxx, PORTn.x | | | | | Indirect addressing regardless of how MBE and MBS are set. (specification in pmem. @L) | BSBn.x<br>PORTn.x | | | | 4-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem). | All hardware where 4-bit manipulation | | | | manipulation | With (MBE=1 and MBS=15), register indirect addressing (specification in @HL). | can be performed. | | | | 8-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem), mem must be an even address. | All hardware where 8-bit manipulation can | | | | manipulation | With MBE=1 and MBS=15, register indirect addressing (specification in @HL; the L register must contain an even number. | be performed. | | | Example: CLR1 MBE ; MBE = 0 SET1 TM0.3 ; Timer 0 starts. El IE0 ; INT0 is enabled. DI IE1 ; INT1 is disabled. SKTCLR IRQ2 : INT2 request flag is tested and cleared. SET1 PORT4. @L; Port 4 is set. IN A, PORT0; A ← port 0 OUT PORT4, XA; Port 5, 4 ← XA Figs. 3.2-1 to 3.2-3 shows the $\mu PD753XX$ I/O map. The columns in the figures mean: · Abbreviation: Name indicating internal hardware address. It can be entered in the instruction operand field. R/W Indicates whether the hardware device can be read or written. - R/W: Read and write are enabled. - Read only is enabled. - Write only is enabled. - · Number of bits that can be manipulated: Indicates the number of bits that can be processed when the hardware device is operated. - O: Bit manipulation is enabled in 1-4, 4-, or 8-bit units as specified in the column. - $\Delta$ : Only some bits can be manipulated. See Remarks for the bits that can be manipulated. - -: Bit manipulation cannot be performed in 1-, 4-, or 8-bit units as specified in the column. - · Bit manipulation addressing: Indicates the applicable bit manipulation addressing for performing bit manipulation on the hardware device. | Address | Hardy | vare nam | e (abbrev | ation) | R/W | | per of bit<br>e manip | | Bit manipulation | Remarks | |---------|----------------------------------------|----------------------|-------------|----------|---------|------------|-----------------------|--------------|------------------|--------------------------------------------------| | | b3 | b2 | b1 | b0 | | One<br>bit | Four<br>bit | Eight<br>bit | addressing | | | F80H | Stook no | intor (CD | \ | | R/W | | | 0 | | Bit 0 is fixed to 0. | | | Stack po | ointer (SP | ) | | I T/ VV | | | U | | | | F85H | Basic intregister | terval time<br>(BTM) | er mode | | w | Δ | 0 | 1 | mem. bit | Bit manipulation can be performed only on bit 3. | | F86 H | Basic in | terval time | er (BT) | | ·R | _ | - 1 | 0 | | | | F8CH | Display | mode reg | ister (LCE | PM) | w | Δ | _ | 0 | mem. bit | Bit manipulation can be performed only on bit 3. | | FOFIL | 5: 1 | | | 20) | | | - | | | | | F8EH | Display | control re | gister (LC | DC) | W | _ | 0 | | | Distant and be as also | | F98H | Watch n | node regis | ster (WM) | | R/W | Δ | _ | 0 | mem. bit | Bit test can be made only on bit 3. | | | | | | | W | _ | | | | | | FA0H | Timer/ev | | ter 0 mod | е | w | Δ, | - | 0 | mem. bit | Bit manipulation can be performed only on bit 3. | | | | | | | | _ | | | | | | FA2H | TOE0<br>(Note) | | | | w | 0 | - | 1 | mem. bit | | | FA4H | Timer/event counter 0 count | | | R | - | - | 0 | | | | | | register (T0) | | | n | 1 | - | ) | | | | | FA6H | Timer/event counter 0 modulo | | | | ·w | _ | | 0 | | | | | register (TMOD0) | | | " | _ | | | | | | | FB0H | 0 | IST0 | MBE | 0 | R/W | 0 | 0 | 0 | | | | 1 5011 | Program status word (PSW) | | | R | _ | - | Ŭ, | | | | | FB2H | (IME) | | | | - | - | - | - | fmem. bit | El and DI instructions are used | | FB3H | Processor clock control register (PCC) | | | | w | _ | 0 | | | | | FB4H | INT0 mc | de regist | er (IM0) | | W | _ | 0 | | | Bit 2 is fixed to 0. | | FB5H | INT1 mo | de regist | er (IM1) | | w | _ | . 0 | - | | Bit 3 to 1 are fixed to 0. | | FB6H | INT2 mo | de regist | er (IM2) | | w | - | 0 | | | Bits 3 and 2 are fixed to 0. | | FB7H | System | clock con | trol regist | er (SCC) | w | 0 | - | - | 1. | Only bits 3 and 0 can be bit manipulated. | Note: TOE0 = timer / event counter 0 output enable flag (W) (to be continued) Figure 3.2-1 µPD753XX I/O Map | Address | Hardv | vare name | e (abbrevi | ation) | R/W | | per of bit<br>e manipi | | Bit manipulation | Remarks | |---------|--------------------------------------------------------|--------------|------------|--------|------|------------|------------------------|--------------|------------------|-----------------------| | | b3 | b2 | b1 | b0 | 1000 | One<br>bit | Four<br>bit | Eight<br>bit | addressing | no. | | FB8H | IE4 | IRQ4 | IEBT | IRQBT | R/W | 0 | 0 | | | | | FBAH | | | IEW | IRQW | R/W | 0 | 0 | - | | | | FBCH | | | IET0 | IRQT0 | R/W | 0 | 0 | 7 | fmem, bit | | | FBDH | | | IECSI | IRQCSI | R/W | 0 | 0 | - T | imem. bit | | | FBEH | IE1 | IRQ1 | IE0 | IRQ0 | R/W | 0 | 0 | | | | | FBFH | | B 11 1 | IE2 | IRQ2 | R/W | 0 | 0 | <del>-</del> | | Section 1985 | | FC0H | Bit sequ | ential buff | er 0 (BSE | 30) | R/W | 0 | 0 | 0 | | | | FC1H | Bit sequ | ential buff | er 1 (BSE | 31) | R/W | 0 | 0 | | mem. bit | 4 | | FC2H | Bit sequ | ential buff | er 2 (BSE | 32) | R/W | 0 | 0 | _ | pmem @L | | | FC3H | Bit sequ | ential buff | er 3 (BSE | 33) | R/W | 0 | 0 | 0 | | | | FD0H | Clock output mode register (CLOM) | | | | | - | 0 | - | | | | FDCH | Pull-up resistor specification register group A (POGA) | | | | w | | | 0 | | | | FE0H | Serial operation mode register (CSIM) | | | | w | | _ | | | | | | CSIE | COI | WUP | | R/W | 0 | 0 | 0 | mem. bit | | | FE2H | CMDD | RELD | CMDT | RELT | | | | | | Only bit manipulation | | | SBI conf | trol registe | er (SBIC) | | R/W | 0 | - | - | mem. bit | can be performed on | | | BSYE | ACKD | ACKE | ACKT | | | | | | any bit. | | FE4H | Serial I/O shift register (SIO) | | | R/W | _ | _ | 0 | | | | | FE6H | Slave address register (SVA) | | | | w | | - | 0 | | | | FE8H | PM33 | PM32 | PM31 | PM30 | | | | | | | | 1 2011 | Port mo | de registe | r group A | (PMGA) | w | _ | _ | 0 | | | | | PM63 | PM62 | PM61 | PM60 | 1 | | | | | | | FECH | _ | PM2 | _ | - | | | | | | | | . 20.1 | Port mo | de registe | r group B | (PMGB) | w | _ | _ | 0 | | | | | PM7 | 0 | PM5 | PM4 | 1 | | | | | | Remarks: 1. IExxx is an interrupt enable flag. 2. IRQxxx is an interrupt request flag. 3. IME is an interrupt master flag. (to be continued) Figure 3.2-1 µPD753XX I/O Map (con`t) | Address | Hardware name (abbreviation) | | | | R/W | Number of bits that can be manipulated | | | Bit manipulation | Remarks | |----------------|------------------------------|----------|------------|---------------|--------|----------------------------------------|-------------|--------------|--------------------|---------| | | b3 | b2 | b1 | b0 | I TVVV | One<br>bit | Four<br>bit | Eight<br>bit | addressing | nemarks | | FF0H | Port 0 | (PORT 0) | | | R | 0 | 0 | _ | | | | FF1H | Port 1 | | (PC | ORT 1) | R | 0 | 0 | | 1 | | | FF2H | Port 2 | | (PC | ORT 2) | R/W | 0 | 0 | | | | | FF3H | Port 3 | (PORT 3) | | | R/W | 0 | 0 | | fmem. bit pmem. @L | | | FF4H | Port 4 | (PORT 4) | | | R/W | 0 | 0 | | | | | FF5H | Port 5 | (PORT 5) | | | R/W | 0 | 0 | | | | | FF6H<br>(Note) | KR3 | KR2 | KR1 | KR0 | R/W | 0 | 0 | | | | | | Port 6 (PORT 6) | | | I-7/VV | O | | 0 | | | | | FF7H<br>(Note) | KR7<br>Port 7 | KR6 | KR5<br>(PC | KR4<br>ORT 7) | R/W | 0 | 0 | | | | Note: KR0-KR7 can only be read. When 4bit parallel is input, specified at PORT6 or PORT7. Figure 3.2-1 µPD753XX I/O Map (con't) ### **4 INTERNAL CPU FUNCTIONS** 4.1 Program Counter (PC) –12–Bit (μPD75304) 13–Bit (μPD75306, 75308) 14–Bit (μPD75312, 75316) The program counter is binary counter which holds program memory address information. The $\mu$ PD75304 is configured of 12-bit (See Fig. 4.1–1 (a)). The $\mu$ PD75306 and 75308 are configured of 13-bit (See Fig. 4.4–1 (b)). The $\mu$ PD75312 and 75316 are configured of 14-bit (See Fig. 4.4–1 (c)). Figure 4.1-1 Program Counter Format Each time one instruction is executed, normally the program counter is automatically incremented according to the number of the bytes in the instruction. When a branch instruction (BR or BRCB) is executed, the register pair contents or immediate data indicating the branch destination address is loaded into all or some of the PC bits. When a subroutine call instruction (CALL or CALLF) is executed or a vectored interrupt occurs, the current PC contents (return address already incremented to fetch the next instruction) are saved in stack memory (data memory indicated by the stack pointer), then the jump destination address is loaded. When a return instruction (RET, RETS, or RETI) is executed, the stack memory contents are loaded into the PC. When the RESET signal is generated, the program memory contents are loaded into the program counter for initialization, as follows: (Program can be started at any desired address.) μPD75304: PC11-PC8 PC7 -PC0 PC8 + Dow-order four bits at address 0000H eight bits at address 0000H low-order six bits at address 0000H eight bits at address 0000H 4.2 Program Memory (ROM) - 4096 Words x Eight bit (µPD75304) 6016 Words x Eight bit (µPD75308) 8016 Words x Eight bit (µPD75308) 12160 Words x Eight bit (µPD75312) 16256 Words x Eight bit (µPD75316) The program memory stores programs, interrupt vector table, GETI instruction look up table, and data such as table data. The program memory of the $\mu$ PD75304, $\mu$ PD75306, $\mu$ PD75308, $\mu$ PD75312, $\mu$ PD75316, is mask programmable ROM. Fig. 4.2–1 to 4.2–5 show the program memory map. The program memory is addressed by using the program counter. Table data can also be referenced by using the table reference instruction (MOVT). The address range for branching by a branch or subroutine call instruction is as shown in Fig. 4.2–1. When a relative branch instruction (BR \$addr) is used, a branch can be made to [PC contents – 15 to –1, +2 to + 16] address independently of block. The program memory addresses are shown below. • 000H- FFFH : µPD75304 • 0000H-177FH : µPD75306 • 0000H-1F7FH : µPD75308 • 0000H-2F7FH : µPD75312 • 0000H-3F7FH : µPD75316 The following addresses are assigned for special purpose: (All the area except address 0000H to 0001H Note 1 can be used as normal program memory area.). ### 0000H – 0001H Vector address table in which the program start address and MBE setup value are entered when the system is reset. (Reset start can be made at any desired address.) #### 0002H – 000BH Vector address table in which the program start address and MBE setup value are entered for each vectored interrupt. (Interrupt service can be started at any desired address.) ## • 0020H - 007FH Table area referenced by GETI (Note 2). Note: 1. Their addresses are used in the μPD753XX. 2. The GETI instruction is used to convert any 2- or 3-byte instruction or any two 1-byte instructions into a 1-byte instruction. The number of program bytes can be reduced. Figure 4.2-1 Program Memory Map (μPD75304) Figure 4.2-2 Program Memory Map (μPD75306) Figure 4.2-3 Program Memory Map (μPD75308) Figure 4.2-4 Program Memory Map (µPD75312) Figure 4.2-5 Program Memory Map (μPD75316) #### 4.3 Data Memory (RAM) - 512 Words x Four Bits The data memory is a general purpose static RAM consisting of 512 words x four bits. Since a static RAM stores data during process, subroutine, or interrupt execution, it can also hold data when CPU operation is stopped in the standby mode; it is useful in that the memory contents can be held with battery power for hours. Fig. 4.3-1 shows a μPD753XX data memory map. The data memory adopts the bank configuration, consisting of banks 0 and 1 (each 256 words x four bits). Peripheral hardware is mapped in the memory bank 15 area. A memory bank is selected by setting the 4-bit memory bank selection register (MBS = 0,1, or 15) when bank specification is enable by setting the memory bank enable flag (MBE) to 1 (MBE = 1). When bank specification is disabled (MBS = 0), memory bank 0 or 15 is automatically selected according to the current addressing mode. Each bank is addressed by using 8-bit immediate data, a register pair, etc. Although a data memory word consists of four bits, the data memory can be handled in 1-, 4-, or 8-bit units by using various addressing modes. See 3.1 for details of memory bank selection and addressing modes. Specific areas of the data memory are also used for general purpose registers (bank 0; 000H – 0007H), stack memory (bank 0; 000H – 0FFH) and display data memory (bank 1; 1E0H – 1FFH). Data memory does not exist in bank 15. Peripheral hardware and various registers are mapped. Do not access addresses or bits to which no registers are allocated. For the use of the specific areas of data memory, see the following: - · 4.4 for the general purpose register area - · 4.6 for the stack memory area - 5.7.5 for the display data memory - · CHAPTER 5 for the peripheral hardware Figure 4.3-1 Data Memory Map The data memory is undefined when the system is reset during normal operation mode (not standby), because of possible memory access at the time of reset. Be sure to initialize it too (clear RAM), normally at the program start. Figure 4.3-2 Display Data Memory Configuration The display data memory is handled in 1- or 4-bit units. Caution: The display data memory cannot be handled in 8-bit units. Example: To clear 1E0H–1FFH display data memory. LOOP: | SET1 | MBE | | | |------|-----------|---|--------------------------------------------------------| | SEL | MB1 | | | | MOV | HL, #0E0H | | | | MOV | A, #00H | | | | MOV | @HL, A | ; | Display data memory is cleared in4-bit units at a time | | INCS | L | | | | BR | LOOP | | | | INCS | Н | | | | BR | LOOP | | | | | | | | ## 4.4 General Purpose Registers - Eight x Four Bits The general purpose registers are eight 4-bit registers (B, C, D, E, H, L, X, and A) mapped in specific addresses of the data memory. Every general purpose register is handled in 4-bit units; register pairs BC, DE, HL, and XA are also used for 8-bit manipulation. In addition to DE and HL, registers D and L are also paired (DL), and the three register pairs can be used for data pointers. The general purpose register area can be addressed and accessed as normal RAM regardless of whether or not it is used for registers. | X<br>01H | A 00H | |----------|-------| | Н | L | | 03Н | 02H | | D | E | | 05H | 04H | | B<br>07H | С 06Н | Figure 4.4-1 General Purpose Register Configuration (When 4-bit processing is performed) | XA | 00H | |----|-----| | HL | 02H | | DE | 04H | | ВС | 06H | Figure 4.4-2 General Purpose Register Configuration (When 8-bit processing is performed) Figure 4.4–3 Register Pair Configuration #### 4.5 Accumulator The μPD753XX uses the A register and XA register pair for accumulators. The A register is used as the main register during execution of 4-bit data processing instructions; the XA register pair is used as the main register pair during execution of 8-bit data processing instructions. The carry flag (CY) is used for a bit accumulator during execution of bit manipulation instructions. Figure 4.5-1 Accumulator ### 4.6 Stack Pointer (SP) - Eight Bits The µPD753XX uses general purpose RAM for stack memory (LIFO). The stack pointer (SP) is an 8-bit register which holds top address information of the stack area. The stack area addresses are 000H-0FFH of memory bank 0 regardless of how MBE and MBS are set. : or CLR1 MBE SP is decremented before data is saved in the stack memory (write operation); it is incremented after data is restored from the stack memory (read operation). Figs. 4.6-2 to 4.6-4 shows data saved in and restored from the stack memory when stack operations are performed. An initial value is set in SP by using an 8-bit memory operation instruction to determine the stack area to be used. The SP contents can also be read. SP0 is always set to 0. It is recommended that the initial value of SP should be set to 00H so that the stack area be used is starting at the most significant address of data memory bank 0 (0FFH). When the RESET signal is generated, the SP contents become undefined. Be sure to initialize SP to the desired value at the start of the program. Example: To initialize SP. SEL MB15 MOV XA, #00H MOV SP, XA SP - 00H Address Symbol 7 6 5 4 3 2 1 0 SP7 SP6 SP5 SP3 SP2 SP1 SP0 SP F80H SP4 Fixed to 0 Figure 4.6-1 Stack Pointer Configuration ### (a) Data Saved in Stack Memory # (b) Data Restored from Stack Memory Figure 4.6-2 Data Saved / Restore of Operation (µPD75304) ### (a) Data Saved in Stack Memory ### (b) Data Restored from Stack Memory Figure 4.6-3 Data Saved / Restored in Stack Operation (µPD75306, 75308) #### (a) Data Saved in Stack Memory ### (b) Data Restored from Stack Memory Figure 4.6-3 Data Saved / Restored in Stack Operation (µPD75312, 75316) # 4.7 Program Status Word (PSW) - Eight Bits The program status word (PSW) consists of flags closely related to processor operation. PSW is mapped in data memory addresses FB0H and FB1H. Two bits of address FB0H can be operated by using a memory operation instruction. Figure 4.7-1 Program Status Word Configuration Table 4.7-1 PSW Flags Saved and Restored when Stack Operation is Performed | | | Saved or restored flag | |---------|------------------------------------------|---------------------------| | Save | During CALL, CALLF instruction execution | MBE is saved | | Save | During hardware interrupt | All PSW bits are saved | | Restore | During RET, RETS instruction execution | MBE is restored | | nestore | During RETI instruction execution | All PSW bits are restored | ### (1) Carry flag (CY) The carry is a 1-bit flag that shows the occurence of overflow or underflow during execution of an instruction involving carry (ADDC or SUBC). The carry flag also serves as a bit accumulator. Boolean algebra operation is performed between the bit accumulator and data memory specified by a bit address. The result can be stored in the bit accumulator. The carry <u>flag</u> is operated by using dedicated instructions independently of other PSW bits. When the RESET signal is generated, the carry flag becomes undefined. Table 4.7-2 Carry Flag Operation Instructions | | Instructions (mnemonic) | Carry flag processing | |------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------| | Instructions dedicated to carry flag operation | SET1 CY<br>CLR1 CY<br>NOT1 CY<br>SKT CY | CY is set to 1<br>CY is cleared<br>CY is inverted<br>Skip if CY is set to 1 | | Bit Boolean instructions | AND1 CY, mem*.bit OR1 CY, mem*.bit XOR1 CY, mem*.bit | The specified bit and CY are ANDed, ORed, or XORed together | | Interrupt service | During interrupt execution | CY is saved in stack<br>memory in parallel with<br>other PSW bits (eight bits) | | interrupt service | RETI | CY is restored from stack<br>memory in parallel with<br>other PSW bits | Remarks: mem\*.bit indicates any of the following three bit 3 manipulation addressing modes - · fmem.bit - · pmem.@L - · @H + mem.bit Example: To AND bit 3 of address 3H and P33 together and set the result in CY. SET1 CY ; CY 1 CLR1 MBE ; Or SEL MB0 SKT 3FH. 3; Skip if bit 3 of address 3FH is set to 1. CLR1 CY ; CY ← 0 AND1 CY, PORT3.3 ; CY ← CY ↑ P33 ## (2) Skip flags (SK2, SK1, and SK0) The skip flags store the skip state and are automatically set or reset when the CPU executes instructions. The user cannot directly use the flags as operands. ## (3) Interrupt status flag (IST0) The interrupt status flag stores the current status of processing being performed. (For details, see Table 6.3–2.) Table 4.7-3 Interrupt Status Flag Indication Contents | IST0 | Status of processing<br>being performed | Processing contents and interrupt control | |------|-----------------------------------------|---------------------------------------------------------------------------| | 0 | Status 0 | During normal program processing.<br>Every interrupt can be acknowledged. | | 1 | Status 1 | During interrupt processing.<br>No interrupt must be acknowledged. | If an interrupt is acknowledged, the IST0 contents are saved in stack memory as a PSW bit, then automatically IST0 is set to 1. When an RETI instruction is executed, IST0 is set to 0. The interrupt status flag can be operated by using a memory operation instruction. The current status of processing can also be changed under program control. Caution: Before operating the flag, be sure to execute a DI instruction to disable interrupts. After operating the flag, execute an EI instruction to enable interrupts. (4) Memory bank enable flag (MBE) The memory bank enable flag is a 1-bit flag used to specify the address information generation mode of the high-order four bits of a 12-bit data memory address. MBS can be set or reset at any time by using a bit manipulation instruction regardless of memory bank setting. Example: SET1 MBE ; MBE ← 1 CLR1 MBE ; MBE ← 0 When MBE is set to 1, the data memory address space is exceeded and all the data memory space can be addressed. When MBE is reset to 0, the data memory address space is fixed regardless of how MBS is set. (see Fig. 3.1-2.) When the RESET signal is generated, the contents of program memory address 0 bit 7 are set and MBE is initialized automatically. When vectored interrupt service is made, bit 7 of the corresponding vector address table is set and the MBE state during interrupt service is set automatically. During interrupt service, normally MBE is set to 0 and the general purpose RAM of memory bank 0 is used. ### 4.8 Bank Selection Register (BS) The memory bank selection register (MBS) for selecting a memory bank is mapped in the bank selection register (BS). The low-order four bits of BS are fixed to 0 MBS is set by using the SEL MBn instructions. BS can be saved in and restored from the stack area in 8-bit units by using PUSH BS instructions. Figure 4.8-1 Bank Selection Register Configuration ### (1) Memory bank selection register (MBS) The memory bank selection register (MBS), consisting of four bits, stores high-order 4-bit address information of a 12-bit data memory address. The memory bank to be accessed is specified according to the register contents. However, the µPD753XX allows the user to select bank 0, bank 1, or bank 15 only. MBS is set by using the SEL MBn instruction (where n is 0, 1, or 15). The address range applied according to how MBE and MBS are set is as shown in Fig. 3.1-2. When the RESET signal is generated, MBS is initialized to 0. ### **5 PERIPHERAL HARDWARE FUNCTIONS** ### 5.1 Digital Input / Output Ports The µPD753XX adopts memory mapped I/O. All input / output ports are mapped in the data memory space. Bit 0 in addresses 1F8H-1FFH is used for output latches for bit port outputs BP0-BP7. For BP0–BP7, bit port output can be switched in 4-bit units by using display mode register (LCDM) bits 6 and 7. (See Fig. 5.7–2) 1F8H–1FFH bits not used for bit port output latches can be used for display memory or general purpose RAM. These addresses can be handled in 1- or 4-bit units. These addresses cannot be handled in 8-bit unit. | Address | 3 | 2 | 1. | 0 | | |---------|-----|-------------|------------------|-----|--------| | FF0H | P03 | P02 | P01 | P00 | PORT 0 | | FF1H | P13 | P12 | P11 | P10 | PORT 1 | | FF2H | P23 | P22 | P21 | P20 | PORT 2 | | FF3H | P33 | P32 | P31 | P30 | PORT 3 | | FF4H | P43 | P42 | P41 | P40 | PORT 4 | | FF5H | P53 | P52 | P51 | P50 | PORT 5 | | FF6H | P63 | P62 | P61 | P60 | PORT 6 | | FF7H | P73 | P72 | P71 | P70 | PORT 7 | | | | <del></del> | | | 1 | | 1F8H | | | _ | BP0 | | | 1F9H | - | | _ | BP1 | | | 1FAH | - | - | · | BP2 | | | 1FBH | | - | - | BP3 | | | 1FCH | - | | · | BP4 | | | 1FDH | - | - | - | BP5 | | | 1FEH | - | | | BP6 | | | 1FFH | | · ** = * · | - · · · <u>-</u> | BP7 | | | | | | | | • | Remarks: The part of – bits can be used for general purpose RAM Figure 5.1-1 Data Memory Addresses of Digital Ports Table 5.1–2 lists the input / output port operation instructions. In addition to 4-bit input / output, 8-bit input / output and bit manipulation can be performed for PORT 4 to PORT 7 and very diverse control can be performed. BP0–BP7 are 1-bit output ports. Example: To test the P13 state and output value to ports 4 and 5 depending on the result. SKT PORT1.3 ; Skip if port 1 bit 3 is set to 1 MOV XA, #18H ; XA 18H String effect MOV XA, #14H ; XA 14H String effect SEL MB15 ; Or CLR1 MBE OUT PORT4, XA ; Ports 5,4 XA Example: SET1 PORT 4. @L; The port 4-7 bit specified by using the L register is set to 1. Example: To output 1 to BP0. SET1 MBE SEL MB1 ; Memory bank 1 is selected 5.1.1 Types, features, and configurations of digital input / output ports Table 5.1-1 lists the digital input / output ports. Figs. 5.1-1 to 5.1-5 shows the port configurations. Table 5.1-1 Types and Features of Digital Ports | Port (abbreviation) | Function | Operation and features | Remarks | | | |---------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--|--| | PORT 0 | 4-bit input | Can always be read or tested regardless | Pins also used for INT4, SCK<br>SO/SB0, SI/SB1. Pins also | | | | PORT 1 | | of the operation mode. | used for INT0-2 and TI0. | | | | PORT 3(Note 1) | | Can be placed in input or output mode in 1-bit units. | Pins also used for LCDCL SYNC and MD0-MD3, (Note 2) | | | | PORT 6 | 4-bit input / output | iri 1-bit uriits. | Pins also used for KR0–KR3. | | | | PORT 2 | 4-bit input / output | Can be placed in input or ouput mode in 4-bit units. Ports 6 and 7 can be | Port 2 pins are also used for PTO0, PCL, and BUZ. | | | | PORT 7 | | paired for data input / output in 8-bit units | Pins also used for KR4–KR7. | | | | PORT 4(Note 1) | 4-bit input / output<br>(N-channel open | Can be placed in input or output mode in 4-bit units. Ports 4 and 5 can be paired | Internal pull-up resistor can be specified in 1-bit units by using | | | | PORT 5(Note 1) | drain 10 Volts) | for data input / output in 8-bit units. | mask option. | | | | BP0-BP7 | 1-bit output | Data is output in 1-bit units. The BP0–<br>BP7 pins are also used as output pins<br>(S24-S31) for the LCD driving segment<br>signal. BP0-BP7 and S24-S31 can be<br>changed by using software. | The capacity of drive is very small. Used for CMOS load drive. | | | Note 1: An LED can be driven directly. Note 2: PORT 3 is also used for MD0-MD3 pin only in µPD75P308 and µPD75P316. The P10 pin is also used for an external vectored interrupt input pin (input with a noise removal circuit). (For details, see 6.3.) The BPO-BP7 pins are also used for driving LCD segment signal output pins (\$24-\$31); they are changed in 4- or 8-pin units by using display mode register (LCDM) bits 6 and 7. BPO-BP7 are 1-bit output ports. Data for bit 0 in each of the display data memory addresses 1F8H-1FFH is output. (See 5.7.5.) When the RESET signal is generated, port 2-port 7 output latches are cleared, the output buffers are turned off, and input mode is entered. Figure 5.1-2 Configuration of Ports 0 or 1 Figure 5.1-3 Configuration of port 3n or 6n (n = 0-3) Figure 5.1-4 Configuration of Port 2 or 7 Figure 5.1-5 Configuration of Port 4 or 5 Symbol Address #### 5.1.2 Input / output mode setting The input or output mode of each input/output ports is set by using the port mode register as shown in Fig. 5.1-6. Each bit of ports 3 and 6 can be placed in input or output mode individually by using port mode register group A (PMGA). Each of ports 2, 4, 5, and 7 (four bits each) is placed in input or output mode individually by using port mode register group B (PMGB). Each port serves as an input port when the corresponding port mode register bit is set to = 0 and serves as an output port when set to 1. Since the output latch contents are applied to the output pins at the same time the output mode is selected by setting the port mode register, the output latch contents must previously be rewitten to the required value before the output mode is set. Port mode register groups A and B are set by using 8-bit memory operation instructions When the RESET signal is generated, all bits of the port mode registers are cleared; thus the output buffers are turned off, and all ports are placed in input mode. Example: To use P30, P31, P62, and P63 for input pins and P32, P33, P60, and P61 for output pins. Or SEL MB15 | CLR1 | MBE | ; | |------|----------|---| | MOV | XA, #3CH | | | MOV | PMGA, XA | | Port mode register group A 3 | Addition | | | | | J . | | | | - Gyllibol | |----------------------------------------------------------|------|------------|---------------|---------------|----------------|----------|------|------|------------| | FE8H | PM63 | PM62 | PM61 | PM60 | PM33 | PM32 | PM31 | PM30 | PMGA | | PM3n P3n, P6n pin input / output specification (n = 0–3) | | | | | | | | | | | | 0 | Input mod | le (output b | uffer off) | | | | | | | PMGA | 1 | Output mo | ode (output | buffer on) | | | | | | | | | | Po | ort mode re | gister group | В | | | | | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1.1 | 0 | Symbol | | FECH | PM7 | | PM5 | PM4 | _ | PM2 | - | | PMGB | | | PMn | Port n inp | ut / output s | specification | n (n = 2, 4, 5 | 5, or 7) | | | | | | 0 | Input mod | le (output b | uffer off) | | | | _ | | | | 1 | Output mo | ode (output | buffer on) | | | | | | <sup>-:</sup> May be 0 or 1. Figure 5.1-6 Port Mode Register Formats ### 5.1.3 Digital input / output port operation instructions Since all input / output ports incorporated in the uPD753XX are mapped in the data memory space, all the data memory operation instructions are applicable. Table 5.1-2 lists the data memory operation instructions particularly useful for input / output pin operation and their application ranges. #### (1) Bit operation instructions The specific address bit direct addressing (fmem. bit) and specific address bit register indirect addressing (pmem. @L) modes are applicable to digital input / output ports PORT 0-PORT 7. The port bits can be operated at any time as desired regardless of how MBE and MBS are set. Example: To OR P50 and P41 together and output the result to P61. AND1 CY, PORT5.0 ; CY ← CY ↑ P50 OR1 CY, PORT4.1 ; CY ← CY ↑ P41 SKT CY BR CLRP SET1 PORT6.1 : P61 − 1 : ## (2) 4-bit operation instructions In addition to the IN and OUT instructions, all 4-bit memory operation instructions such as MOV, XCH, ADDS, and INCS can be used. However, memory bank 15 must have been selected before executing an instruction. Example 1: To output the accumulator contents to port 3. SEL MB15 ; Or CLR1 MBE OUT PORT3, A Example 2: To add the accumulator value to the data output to port 5 and output the result. SET1 MBE SEL MB15 MOV HL, #PORT5 ADDS A, @HL ; A← A+PORT5 NOP MOV @HL, A ; PORT5 ← A Example 3: To test whether or not data in port 4 is greater than the accumulator value. SET1 MBE SEL MB15 MOV HL, #PORT4 SUBS A, @HL ; A<PORT4 BR NO ; NO ; YES ## (3) 8-bit operation instructions In addition to the IN and OUT instructions, the MOV, XCH and SKE instructions can be used for ports 4 and 5 where 8-bit operation (manipulation) can be performed. As with the 4-bit operation instructions, memory bank 15 must have been selected before executing the instruction. Example: To output data in the BC register pair to the output ports specified by the 8-bit data input from ports 4 and 5. SET 1 MBE SEL MB15 IN XA, PORT 4 ; XA ← ports 5 and 4 MOV HL, XA ; HL ← XA MOV XA, BC ; XA ← BC MOV @HL, XA ; Port (L) ← XA Table 5.1-2 Input / Output Port Pin Operation Instruction List | PORT<br>Instruction | PORT<br>0 | PORT<br>1 | PORT<br>2 | PORT<br>3 | PORT<br>4 | PORT<br>5 | PORT<br>6 | PORT<br>7 | BIT•PORT<br>0–7 | |--------------------------------|-----------|-----------|-----------|-------------------|-----------|-----------|------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IN A, PORTn<br>(Note 1) | | 0 | | | | | | | <del>-</del> | | IN XA, PORTn<br>(Note 1) | - | - | - | - 0 | | | ( | ) | | | OUT PORTn. A<br>(Note 1) | - | _ | | | ( | ) | | | MOV mem, A<br>(Notes 3 and 4) | | OUT PORTn. XA<br>(Note 1) | | <u> </u> | - | _ : : : : : : : : | ( | <b>)</b> | 1 ( | 0 | | | SET1 PORTn. bit | | - | | | ( | ) | | | SET1 BPn<br>(Note 3) | | SET1 PORTn. @L<br>(Note 2) | | _ 1 | 141 1 | | ( | <b>ס</b> | | | 1911 <u>- 1</u> 1911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 - 11911 | | CLR1 PORTn. bit | - | - | | \$ 20 | ( | ) | | | CLR1 BPn<br>(Note 3) | | CLR1 PORTn. @L<br>(Note 2) | | - | | | ( | ) | | | 2 42 <u>2</u> | | SKT PORTn. bit | | | | . ( | 0 | | | | SKT BPn<br>(Note 3) | | SKT PORTn. @L<br>(Note 2) | | | | ( | ) | | | | - | | SKF PORTn. bit | | | | ( | 0 | | | | SKF BPn<br>(Note 3) | | SKF PORTn. @L<br>(Note 2) | | 0 | | | | | | - | | | AND1 CY, PORTn. bit | | 0 | | | | | AND1 CY, @H+BPn<br>(Notes 3 and 5) | | | | AND1 CY, PORTn. @L<br>(Note 2) | | 0 | | | | | <del>-</del> | | | | OR1 CY, PORTn. bit | | 0 | | | | | | OR1 CY, @H+BPn<br>(Notes 3 and 5) | | | OR1 CY, PORTn. @L<br>(Note 2) | | 0 | | | | | | - | | | XOR1 CY, PORTn. bit | 0 | | | | | | XOR1 CY, @H+BPn<br>(Notes 3 and 5) | | | | XOR1 CY, PORTn. @L<br>(Note 2) | | 0 | | | | | - | | | Note 1: MBE = 0 or (MBE = 1 and MBS = 15) must have been set before executing the instruction. <sup>2:</sup> The low-order two bits of address and the bit address are specified indirectly by using the L register. <sup>3: (</sup>MBE = 1 and MBS = 1) must have been set before executing the instruction. <sup>4:</sup> Accumulator A bit 0 corresponds to BPn. <sup>5:</sup> Write FH into the H register. ### 5.1.4 Digital input / output port operation When data memory operation instructions are executed for the digital input / output ports, port (pin) operation varries according to which mode (input or output) is set. (See table 5.1–3.) This is because as understood from the input / output port structure, data read into the internal bus is data for each pin in the input mode and output latch data in the output mode. (1) Operation when input mode is set Pin data is operated when executing a test instruction such as SKT or an instruction to read 4- or 8-bit port data into the internal bus (IN, OUT, operation, or comparison instruction). When an instruction to transfer the accumulator contents (four or eight bits) to a port or ports is executed (OUT or MOV instruction), the accumulator data is latched in the output latches. The output buffers remain off. When an XCH instruction is executed, pin data is input to the accumulator and the accumulator data is latched in the output latches. The output buffers remain off. When an INCS instruction is executed, data resulting from adding 1 to 4-bit pin data is latched in the output latches. The output buffer remain off. When an instruction to rewrite data memory bitwise is executed, such as SET1, CLR1, or SKTCLR, (the specifed bit output latch can be rewritten as specified by instruction), but the contents of the output latch for other bits become undefined. (2) Operation when output mode is set When a test instruction or an instruction to read 4- or 8-bit port data into the internal bus is executed, the output latch contents are operated. When an instruction to transfer the accumulator contents (four or eight bits) is executed, output latch data is rewritten and at the same time as output from the pins. When an XCH instruction is executed, the output latch contents are transferred to the accumulator, and the accumulator contents are held in the output latches and is output from the pins. When an INCS instruction is executed, data resulting from incrementing the output latch contents by one is held in the output latches and output from the pins. When a bit output instruction is executed, the specified output latch bit is rewritten and output from the pin. Table 5.1-3 Operation When Input / Output Ports are Used | Executed | Port (pin) | operation | | | |---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|--| | instruction | Input mode | Output mode | | | | SKT ① | Pin data is tested. | Output latch is data tested. | | | | AND1 CY, ① OR1 CY, ① XOR1 CY, ① | Operation is performed between pin data and CY. | Operation is performed between output latch data and CY. | | | | IN A, PORTn<br>IN XA, PORTn<br>MOV A, @HL<br>MOV XA, @HL | Pin data is transferred to accumulator. | Output latch data is transferred to accumulator | | | | ADDS A, @HL ADDC A, @HL SUBS A, @HL SUBC A, @HL AND A, @HL OR A, @HL XOR A, @HL | Operation is performed between pin data and accumulator. | Operation is performed between output latch data and accumulator. | | | | SKE A, @HL | Pin data and accumulator contents are compared. | Output latch data and accumulator contents are compared. | | | | OUT PORTn, A<br>OUT PORTn, XA<br>MOV @HL, A<br>MOV @HL, XA | Accumulator data is transferred to output latches. (Output buffers remain off.) | Accumulator data is transferred to output latches and output from the pins. | | | | XCH A, PORTn<br>XCH XA, PORTn<br>XCH A, @HL<br>XCH XA, @HL | Pin data is transferred to accumulator and<br>accumulator data is transferred to output<br>latches.<br>(Output buffers remain off.) | Data is exchanged between output latches and the accumulator. | | | | INCS PORTn<br>INCS @HL | Data resulting from incrementing pin data by one is latched in output latches. | The output latch contents are incremented by one. | | | | SET1 ① CLR1 ① SKTCLR ① | The specified bit output latches are rewritten as specified by the instruction, but the output latch contents for other bits are undefined. | The output pin state is changed according to the instruction. | | | <sup>:</sup> Denotes two addressing modes PORTn. bit and PORTn. @L. #### 5.1.5 Internal pull-up resistors Pull-up resistors can be incorporated in the $\mu$ PD753XX port pins except P00 or BP0-BP7. Internal pull-up resistors are specified by using software or mask option. #### Pull-up register specification register group A Address 7 6 Symbol 3 0 PO6 PO2 **FDCH** PO7 PO<sub>3</sub> PO<sub>1</sub> PO0 **POGA** Port 0 (P01-P03) Port 1 (P10-P13) Port 2 (P20-P23) Port 3 (P30-P33) Port 6 (P60-P63) Port 7 (P70-P73) Specification Pull-up resistor is not incorporated. Pull-up resistor is incorporated. Figure 5.1–7 Pull-Up Register Specification Register Format Table 5.1-4 | Port (pin names) | Internal pull-up resistor specification method | Specification Bit in POGA | |---------------------------|-------------------------------------------------------------------------|---------------------------| | Port 0 (P01-P03) (Note 1) | Software is used for internal resistor specification in 3-bit units. | Bit 0 | | Port 1 (P10-P13) | | Bit 1 | | Port 2 (P20-P23) | | Bit 2 | | Port 3 (P30-P33) | Software is used for internal resistor specification in 4-bit units. | Bit 3 | | Port 6 (P60-P63) | | Bit 6 | | Port 7 (P70-P73) | | Bit 7 | | Port 4 (P40-P43) | | | | Port 5 (P50-P53) | Mask option is used for internal resistor specification in 1-bit units. | | Note: A pull-up resistor cannot be incorporated in the P00 Pin. 5.1.6 Digital input / output port input / output timing Fig. 5.1–8 shows timing of data to output latch and timing of pin data or output latch data input to the internal bus. Fig. 5.1-9 shows the ON timing at specified the internal pull-up resistor by software. 0 Figure 5.1-9 ON Timing of Pull-up Resistor by using Software ### 5.2 Clock Generator The clock generator supplies clocks to CPU and peripheral hardware for controlling the CPU operating mode. 5.2.1 Clock generator configuration Fig. 5.2-1 shows a clock generator block diagram. Subsystem clock frequency PCC : Processor clock control register 4. SCC: System clock control register 5. \* denotes instruction execution. Figure 5.2-1 Clock Generator Block Diagram ### 5.2.2 Clock generator function and operation The clock generator produces the following clocks and controls CPU operating modes such as standby: - Main system clock fx - Subsystem clock f<sub>xT</sub> - CPU clock ø - Clock to peripheral hardware The clock generator operates according to how the processor clock control register (PCC) and system clock control register (SCC) are set, as described below: - (a) When the RESET signal is generated, the minimum speed mode of the main system clock (15.3 μ/4.19 MHz) is selected. (PCC = 0 and SCC = 0) - (b) When the main system clock is selected, one of three CPU clock frequencies can be selected (0.95 μs, 1.91 μs, and 15.3 μs/ 4.19 MHz) by setting PCC. - (c) When the main system clock is selected, the standby mode (STOP or HALT) can be used. - (d) Subsystem clock is selected by setting SCC.0 and operation can be performed in a very low-speed and low current consumption (122 μs/32.768 kHz). In this case, the PCC setup value does not affect the CPU clock. - (e) When the subsystem clock is selected, main system clock oscillation can be stopped by setting SCC.3. The HALT mode can also be used, but the STOP mode cannot be used. (Subsystem clock oscillation cannot be stopped. - (f) The main system clock is divided to generate a clock supplied to peripheral hardware. The subsystem clock can be supplied directly only to the watch timer. Thus, the watch function and the LCD controlller and buzzer output function which operate using the watch timer clock can also continue operation in the standby mode. - (g) When subsystem clock is selected, the watch timer and LCD controller can continue normal operation. When the main system clock is stopped, other hardware devices than the watch timer or LCD controller cannot be used because they operate according to the main system clock. - (1) Processor clock control register (PCC) PCC consists of four bits; the low-order two bits are used to select CPU clock $\phi$ , and the high-order two bits are used to control CPU operation mode. (See Fig. 5.2-2.) When bit 3 or 2 is set to (1), the standby mode is set. When the standby mode is released by the standby mode release signal, automatically bits 3 and 2 are cleared and the normal operating mode is entered. (For details, see Paragraph 7). The low-order two bits of PCC are set by using a 4-bit memory operation instruction (the high-order two bits are set 0). Bits 3 and 2 are set to (1) by using STOP and HALT instructions respectively. The STOP and HALT instructions can always be executed independently of the MBE contents. CPU clock can be selected only during main system clock operation. When the $\mu$ PD753XX is operated on the subsystem clock, the low-order two bits of PCC becomes invalid, and the CPU clock is fixed to $f_{\chi \gamma}/4$ . The stop instruction is also enabled only during main system operation. Example 1: To set a machine cycle to 0.95 µs (4.19) MHz). SEL MB15 MOV A, #0011B MOV PCC, A Example 2: To set STOP mode. (Be sure to enter a NOP instruction following the STOP or HALT instruction.) STOP NOP When the RESET signal is generated, PCC is cleared. Figure 5.2-2 Processor Clock Control Register Format ## (2) System clock control register (SCC) SCC consists of four bits; the least significant bit is used to select CPU clock, and the most significant bit is used to control (stop) main system clock oscillation. (See Fig. 5.2–3.) SCC.0 and SCC.3 exist at the same data memory address; the bits cannot be changed at the same time. Thus, SCC.0 and SCC.3 are set by using a bit operation instruction. SCC.0 and SCC.3 can always be operated independently of the MBE contents. Main system clock oscillation can be stopped by setting SCC.3 only during subsystem clock operation. Main system clock oscillation is stopped by using the STOP instruction during main system clock operation. When the RESET signal is generated, SCC is cleared. Figure 5.2-3 System Clock Control Register Format - Caution 1: Changing the system clock requires a maximum of 1/f<sub>XT</sub> time. To stop main system clock after changing the subsystem clock, set SCC.3 after the machine cycle or cycles listed in Table 5.2–1. - 2: Even if oscillation is stopped by setting SCC 3 during main system clock operation, normal STOP mode is not entered. - 3: When SCC.3 is set to 1, X1 input is connected internally to V<sub>SS</sub>, to avoid leakage current due to crystall oscillator. When the external clock is used in main system clock, do not set SCC.3 to 1. - 4: When the system clock is switched to the subsystem clock it is necessary to disable any interrupt during the time given in table 5.2-1. #### (3) System clock oscillators The main system clock oscillator uses a crystal oscillator (4.194304 MHz standard) or cermanic oscillator connected to the X1 and X2 pins. An external clock can also be input. Figure 5.2-4 External Circuit to Main System Clock Oscillator Caution: When an external clock is input, the STOP mode cannot be set because the X1 pin is connected to V<sub>SS</sub> in the STOP mode. The subsystem clock oscillator uses a crystal oscillator (32.768 kHz standard) connected to the XT1 and XT2 pins. An external clock can also be input. The XT1 pin state can be tested by using watch mode register (WM) bit 3. Figure 5.2-5 External Circuit to Subsystem Clock Oscillator (4) Frequency divider The frequency divider divides the main system clock oscillator output (f<sub>v</sub>) and generates various clocks. 5.2.3 System clock and CPU clock setting (1) Time required to change system and CPU clocks The system and CPU clocks can be changed by using the low-order two bits of PCC and the least significant bit of SCC. However, this clock change is not immediatly made after the register are rewritten, and the clock before the clock change is made is used for operation during given machine cycles. Thus, to stop main system clock oscillation, a STOP instruction must be executed or SCC 3 must be set after the change time elapses. Table 5.2-1 Maximum Time Required to Change System and CPU Clocks | Setup value before change | | Setup value after change | | | | | | | | | | | | | |---------------------------|-----|--------------------------|----------------------------------------------|----------------------------|------|---------------------------------------------|---------------------------|------------------|---------------------------------------------|---------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------|------|------| | SCC | PCC | PCC | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | Х | Х | | | 0 | 0 | | | | 1 machine cycle | | | 1 machine cycle | | | f <sub>X</sub> machine 64f <sub>XT</sub> cycle (2 machine cycles) | | | | 0 | 1 | 0 | 8 machine cycles | | | | | 8 machine cycles | | | f <sub>X</sub> machine 8f <sub>XT</sub> cycles (16 machine cycles) | | | | | | 1 | 1 | 16 machine cycles | | | 16 machine cycles | | | | | | f <sub>X</sub> machine 4f <sub>XT</sub> cycles (32 machine cycles) | | | | 1 | х | × | f <sub>X</sub><br>64f <sub>X1</sub><br>(2 ma | mach<br>cycle<br>achine cy | s | f <sub>X</sub><br>8f <sub>XT</sub><br>(16 m | macl<br>cycle<br>achine c | s | f <sub>X</sub><br>4f <sub>XT</sub><br>(32 m | mach<br>cycle<br>achine c | s | | _ | | The values enclosed in parentheses are applied when $f_x = 4.19$ MHz and $f_{xT} = 32.768$ kHz. Remarks: The CPU clock $\Phi$ is supplied to the $\mu$ PD753XX internal CPU. The reciprocal of the clock becomes the minimum instruction time. (The present manual defines it to be one machine cycle.) (2) System and CPU clock change sequence System and CPU clock change is explained using Fig. 5.2–6. Figure 5.2-6 System and CPU Clock Change - 1) When the RESET signal is generated, the CPU starts operating at the minimum speed of the main system clock (15.3 µs / 4.19 MHz) after the wait time (31.3 ms / 4.19 MHz) to allow time for stabilizing the oscillator. - After enough time has elapsed for the V<sub>DD</sub> pin voltage to rise to an adequate level PCC is rewritten and the μPD753XX operates at the maximum speed. - 3) Turning off the commercial power supply is detected by using interrupt input (INT4 is useful); SCC. 0 is set, and the µPD753XX operates using the subsystem clock. (At the time, a check must have been made to ensure that subsystem clock oscillation has started. After the time required to change to the subsystem clock (32 machine cycles) has elapsed, SCC 3 is set and main system clock oscillation is stopped. - 4) Restoration of the commercial power supply is detected by using an interrupt. SCC. 3 is cleared and main system clock osscillation is started. After the time required to stabilize oscillation has elapsed, SCC. 0 is cleared and the µPD753XX operates at the maximum speed. #### 5.2.4 Clock output circuit (1) Clock output circuit configuration Fig. 5.2-7 shows a clock output circuit block diagram. (2) Clock output circuit function The clock output circuit, which outputs clock pulses from the P22/PCL pin, is used to supply clock pulses to remote control output or peripheral LSIs. Clock pulses are output in the following sequence: - (a) Clock output frequency is selected. Clock output is disabled. - (b) 0 is written into P22 output latch. - (c) Port 2 input/output mode is placed in output mode. - (d) Clock output is enabled. Figure 5.2-7 Clock Output Circuit Block Diagram Remarks: The circuit is designed so as not to output a spurious short-width pulse when changing between clock output enable and disable. (3) Clock output mode register (CLOM) CLOM is a 4-bit register to control clock output. CLOM is set by using a 4-bit memory operation instruction. It cannot be read. Example: To output clock Φ from PCL/P22 pin. SEL MB15 ; Or CLR1 MBE MOV A, #1000B MOV CLOM, A When the RESET signal is generated, CLOM is cleared and clock output is disabled. Caution: Be sure to write 0 into CLOM bit 2. Figure 5.2-8 Clock Output Mode Register Format (4) Application example to remote control output The µPD753XX clock output function is applicable to remote control output. Remote control output carrier frequency is selected by using the clock frequency selection bit of the clock output mode register. Pulse output is enabled or disabled under software control by using the clock output enable/disable bit. It is designed so that a spurious short-width pulse will not be produced when changing between clock output enable and disable. Figure 5.2-9 Remote Control Output Application Example ### 5.3 Basic Interval Timer The µPD753XX contains an 8-bit basic interval timer which has the following functions: - (a) Reference time generation (four types of time interval) - (b) Wait time selection and count when standby mode is released. - (c) Count read The basic interval timer can also be applied to a watchdog timer to detect program overrun. ## 5.3.1 Basic interval timer configuration Fig. 5.3-1 shows the configuration of the basic interval timer Remarks: \* denotes instruction executing. Figure 5.3-1 Basic Interval Timer Configuration ### 5.3.2. Basic interval timer mode register (BTM) BTM is a 4-bit register for controlling operation of the basic interval timer. BTM is set by using a 4-bit memory operation instruction. Bit 3 can be set individually by using a bit operation instruction. Example 1: To set the interrupt generation interval to 1.95 ms (4.19 MHz). SEL MB15 ; or CLR1 MBE MOV A, # 1111B Example 2: To clear BT and IRQBT (watchdog timer application). SEL MB15 ; or CLR1 MBE SET1 BTM.3 ; BTM BIT 3 is set to 1. When bit 3 is set to 1, the basic interval timer contents are cleared. At the same time, the basic interval interrupt request flag (IRQBT) is also cleared. (The basic interval timer starts.) When the RESET signal is generated, the BTM contents are cleared and interrupt request signal generation is set for the longest interval. Fig. 5.3-2 Basic Interval Timer Mode Register Format ## 5.3.3. Basic interval timer operation The basic interval timer (BT) is incremented each time a pulse is received from the clock generator. When an overflow occurs, the interrupt request flag (IRQQBT) is set. BT count operation cannot be stopped. An interrupt generation time interval can be selected from among four types by setting BTM. (See Fig. 5.3—2.) The basic interval timer and interrupt request flag can be cleared by setting BTM bit 3 to 1 (the interval timer function starts). The basic interval timer (BT) count can be read by using an 8-bit operation instruction. Data cannot be written into BT. ## Caution: To prevent reading of unstable data during count update when reading the basic interval timer count, execute the read instruction twice and compare the results. If they are valid values, the later read value is used as the read result, if they differ from each other completely, reexecute from the beginning. Example: To read the BT count SET1 MBE SEL **MB15** MOV HL, #BT BT address is set in HL. LOOP: MOV XA, @HL First read MOV BC, XA MOV Second read XA, @ HL SKE A, C BR LOOP MOV A. X SKE A, B BR LOOP The wait function is provided to stop CPU operation until the basic interval timer overflows in order to allow time for system clock oscillation to become stable when the STOP mode is released. Although the wait time after the RESET signal is generated is fixed, it can be selected by setting BTM when the STOP mode is released by an interrupt. The wait time is selected by setting BTM as shown in Fig. 5.3—2. BTM setting must be performed before the STOP mode is set. (For details, see CHAPTER 7.) #### 5.3.4 Basic interval timer application examples Example 1: To enable basic interval timer interrupt and set interrupt generation interval at 1.95 ms (at 4.19 MHz). SEL MB 15 MOV A, #1111B MOV BTM, A ; E MOV BTM, A ; BTM setting and timer function start EI ; Interrupt is enabled. El IEBT ; BT interrupt is enabled. ## Example 2: Watchdog timer application A program is divided into serval modules which terminate processing within the BT setup time. BT and IRQBT are cleared at the end of each module. If an interrupt is generated, overrun is assumed to have occurred. SEL MB15 Initial- MOV A, #1101B ; 7.8 ms interval is set. ization MOV BTM, A ; BTM setting and timer function start EI EEI IEBT ı Processing is completed within Module 1 SEL MB15 7.8 ms. SET1 втм.з Processing is Module 2 MB15 completed within SEL 7.8 ms. SET1 BTM.3 Example 3: To set the wait time, when the STOP mode is released, using an interrupt to 7.8 ms. SEL MB15 : or CLR1 MBE A, #1101B MOV BTM, A ; BTM ← 1101B STOP ; STOP mode is set NOP MOV #### Example 4: To set the high-level width of a pulse input to INT4 interupt (both rising and falling edge detection). (The pulse width must not exceed the BT setup value. The BT setup value must be 7.8 ms or more.) < INT4 interrupt routine (MBE = 0) > MOV XA, BT First read MOV BC. XA Data is stored. MOV XA, BT Second read SKE A, C BR LOOP MOV A, X SKE A, B BR LOOP SKT PORT0.0 P00=1? BR NO AA MOV XA, BC Data is stored in data memory. MOV BUFF, XA CLR1 FLAG **RFTI** AA: MOV HL. #BUFF MOV A, C SUBC A, @HL **INCS** MOV C, A MOV A, X SUBC A, @HL MOV B. A MOV XA. BC MOV BUFF, XA Data is stored. SET1 FLAG Data existence flag is set. RETI ## 5.4 Watch Timer The µPD753XX incorporates a watch timer (one channel) which has the following function: - (a) The test flag (IRQW) is set at 0.5 s time intervales. The standby mode can be released using IRQW. - (b) The main system and subsystem clocks can be assigned 0.5-s intervals. - (c) In the rapid feed mode, time intervals multiplied by 128 (3.91 ms) are enabled. The mode is useful for program debugging and testing. - (d) A fixed frequency (2.048 kHz) can be output to P23/BUZ. It can be used for sounding the buzzer and trimming the system clock oscillation frequency. - (e) Since the scaler can be cleared, the watch can be started at zero seconds. ## 5.4.1 Watch timer configuration Fig. 5.4-1 shows a watch timer block diagram. The values enclosed in parentheses are applied when $f_x = 4.194304$ MHz and $f_{xT} = 32.768$ kHz. Figure 5.4-1 Watch Timer Block Diagram # 5.4.2 Watch mode register The watch dog timer (WM) consists of eight bits to control the watch timer. Fig. 5.4-2 shows the watch mode register format. The watch mode register (except bit 3) is set using an 8-bit operation instruction. Bit 3 is used to test the XT1 pin input level. The input level to the XT1 pin can be tested by making a bit test. When the RESET signal is generated, all bits except bit 3 are cleared. Example: To produce time using the main system clock (4.19 MHz). To enable buzzer output. CLR<sub>1</sub> MBE MOV XA, #84H MOV WM, XA : WM set Address F98H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | |-----|---|---|---|-----|-----|-----|-----|--------| | WM7 | 0 | 0 | 0 | wмз | WM2 | WM1 | WM0 | WM | Count clock (fw) selection bit | WMO | 0 | System clock dividing output $\frac{f_X}{128}$ is selected. | |-----|---|-------------------------------------------------------------| | | 1 | Subsystem clock f <sub>XT</sub> is selected. | ## Operation mode selection bit | WM1 | 0 | Normal watch mode (IRQW is set by using $\frac{f_W}{2^{14}}$ , 0.5 s) | |--------|---|------------------------------------------------------------------------| | VVIVII | 1 | Rapid feed watch mode (IRQW is set by using $\frac{f_W}{2}$ , 3.91 ms) | #### Watch operation enable/disable bit | WM2 | 0 | Watch operation is stopped (divider is cleared). | |--------|---|--------------------------------------------------| | VVIVIZ | 1 | Watch operation is enabled. | ## Input level to XT1 pin (bit test only is enabled) | WM3 | 0 | Input level to XT1 pin is low. | |-----|---|---------------------------------| | WM3 | 1 | Input level to XT1 pin is high. | ## BUZ output enable/disable bit | WM7 | 0 | BUZ output is disabled. | |--------|---|-------------------------| | ****** | 1 | BUZ output is enabled. | Figure 5.4-2 Watch Mode Register Format # 5.5 Timer/event counter configuration The $\mu PD753XX$ incorporates a timer/event counter (one channel) as shown in Fig. 5.5–1. The timer/event counter functions are as follows: - (a) Programmable interval timer operation - (b) Any desired frequency square wave output to PTO0 pin - (c) Event counter operation - (d) TI0 pin input is divided by N output to PTO0 pin (scaler operation). - (e) Real shift clock supply to serial interface circuit - (f) Count read function Figure 5.5–1 Timer/Event Counter Block Diagram #### 5.5.2 Basic configuration and operation of timer/event counter The timer/event counter operation mode can be selected by using the timer/event counter mode register (TM0). The basic configuration and operation of the timer/event counter are explained below: - (1) Count pulse CP is selected by setting TM0 and input to the 8-bit count register T0. - (2) To is a binary 8-bit up counter incremented by one when CP is input. It is cleared when the RESET signal is generated, TM0 bit 3 is set (timer start), or coincidence signal is generated. To can be read at any time using an 8-bit memory operation instruction, but cannot be written - (3) The modulo register TMOD0 consists of eight bits to determine the TO count. A value is set in TMOD0 using an 8-bit memory operation instruction, but TMOD0 cannot be read. When the RESET signal is generated, TMOD0 is initialized to FFH - (4) The comparator compares the T0 and TMOD0 contents. If they match, it generates a coincidence signal and sets the interrupt request flag (IRQT0) - Fig. 5.5-2 shows the count operation timing. Figure 5.5-2 Count Operation Timing Chart # 5.5.3 Timer/event counter mode register (TM0) and timer/event counter output enable flag (TOE0) The mode register (TM0) consists of eight bits to control the timer/event counter. Fig. 5.5–3 shows the timer/event counter mode register format. The timer mode register is set by using an 8-bit memory operation instruction. Bit 3 is a timer start bit which can be set individually. Bit 3 is reset to 0 automatically when timer operation starts. Example 1: To start the timer in interval timer mode with CP = 4.09 kHz. Example 2: To restart the timer according to how the timer mode register is set. SEL MB15 ; or CLR1 MBE SET1 TM0.3 ; TM0.BIT3 ─ 1 When the RESET signal is generated, all the timer mode register bits are cleared. The timer/event counter output enable flag (TOE0) controls enable/disable of outputting the timer out F/F (TOUT F/F) state to the PTO0 pin. (See Fig. 5.5–4.) It is operated by using bit operation instruction and is enable to be writing. The timer out F/F (TOUT F/F) is inverted by the coincidence signal received from the comparator. The timer out F/F is reset using an instruction to set timer mode register (TM0) bit 3. When the RESET signal is generated, TOE0 and TOUT F/F are cleared. Remarks: The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. Figure 5.5-3 Timer/Event Coumter Mode Register Format Figure 5.5-4 Timer/Event Counter Output Enable Flag Format ## 5.5.4 Timer/event counter operation mode The timer/event counter operates in the count operation stop or count operation mode depending on how the mode register is set. The following are always enabled independently of how the mode register is set - 1) TIO pin signal input and test. (P13 pin input test can be made.) - 2) Output of timer out F/F state to PTO0. - 3) Modulo register (TMOD0) setting. - 4) Count register (T0) read. - 5) Interrupt request flag (IRQT0) setting, clear, and test - (a) Count operation stop mode The count operation stop mode is set when TM0 bit 2 is set to 0. Since count pulse (CP) supply to the count register is stopped, count operation is not performed (b) Count operation mode The count operation mode is set when TM0 bit 2 is set to 1. Count pulses selected by using bits 4 to 6 are supplied to the count register, and count operation is performed as shown in Fig. 5.5-2. Normally, timer operation is started by - 1) setting a count value in the modulo register (TMOD0), then - setting the operation mode, count clock, and start indication in the mode register (TM0). The modulo register is set by using an 8-bit data transfer instruction. Caution: Set a value other than 0 in the modulo register. Example: To set 3FH in channel 0 modulo register. SEL MB15 or CLR1 MBE MOV XA, #3FH MOV TMOD0, XA Figure 5.5-5 Operation in Count Operation Mode # 5.5.5 Timer/event counter time setting "Timer setup value" (period) is equal to "modulo register contents + 1" divided by "count pulse frequency" selected by setting the timer mode register. $$T(s) = \frac{n+1}{F_{CP}}$$ $\begin{array}{ll} {\sf T} \ ({\sf s}) & : {\sf Timer} \ {\sf setup} \ {\sf value} \ ({\sf seconds}) \\ {\sf F}_{\sf CP} \ ({\sf Hz}) \ : {\sf Count} \ {\sf pulse} \ {\sf frequency} \ ({\sf Hz}) \end{array}$ n : Modulo register value (n ≠ 0) Once the timer is set, an interrupt request signal (IRQT0) is generated at the setup time intervals. Table 5.5–1 lists the resolution and maximum setup value (time when FFH is set in the modulo register) of the timer/event counter for each count pulse. Example: To produce 30 ms time intervals. ( $f_x = 4.194304 \text{ MHz}$ ) Use the mode with the maximum setup time 62.5 ms. $$\frac{30 \text{ ms}}{244 \text{ }\mu\text{s}} = 122.9 = 7\text{AH}$$ Set 79H in the modulo register. SEL MB15 MOV XA, #79H MOV TMOD0. XA Table 5.5-1 Resolution and Maximum Setup Value (4.19 MHz) | М | ode regist | er | Timer channel 0 | | | |------|------------|------|-----------------|--------------------|--| | TMO6 | TMO5 | TMO4 | Resolution | Maximum setup time | | | 1 | 0 | 0 | 244 μs | 62.5 ms | | | 1 | 0 | 1 | 61.1 μs | 15.6 ms | | | 1 | 1 | 0 | 15.3 μs | 3.91 ms | | | 1 | 1 | 1 | 3.81 μs | 977 μs | | #### 5.5.6 Caution on timer/event counter application # (1) Error at timer start An error with a maximum length of one clock period of the count pulse (CP) for the value calculated in 5.5.5 occurs in the time until a coincidence signal is generated after the timer starts (TM0.3 is set). This is because clearing of the count register is not synchronized with CP as shown in Fig. 5.5–6. Figure 5.5-6 Error at Timer Starting #### (2) Caution at timer start Normally, the count register T0 and interrupt request flag IRQT0 are cleared when the timer starts (TM0 bit 3 is set). However, if the timer is placed in the operation mode, and IRQT0 setting and timer start occur simultaneously, IRQT0 may be unable to clear. There is no problem when IRQT0 is used for a vectored interrupt. In IRQT0 test application, however, a problem arises such than IRQT0 is set although the timer has been started. Thus, to start the timer at IRQT0 timing, stop the timer once (by setting TM0 bit 2 to 0), then restart it, or start the timer twice. Example: Timer start at IRQT0 timing may be set SEL MB15 ; or CLR1 MBE MOV XA, #0 MOV TM0, XA ; Timer stop MOV XA, #4CH MOV TM0, XA ; Restart or SEL MB15 ; or CLR1 MBE SET1 TM0.3 SET1 TM0.3 ; Restart # (3) Error at count register read The count register contents can be read at any time using an 8-bit data memory operation instruction. During execution of the instruction, count pulse change is held and count register change is suppressed. Thus, if the count pulse signal source is input to TIO, count pulses as long as the instruction execution time are deleted. (This symptom does not occur if the internal clock is used for count pulses because they are synchronized with the instruction.) Therefore, if TI0 is input as a count pulse and the count register contents are read, signals having a pulse width that prevents miscount, even if count pulses are deleted, must be input. Since the count hold period in read instruction execution is one machine cycle, the pulse width input to the TI0 pin must be longer than one machine cycle. # (4) Caution at count pulse change If the timer mode register is rewritten and count pulse change is made, its specification becomes effective immediately after instruction execution. A count pulse (1) or 2) in the timing chart shown below) may occur depending on the clock combination when the count pulse changed. In this case, a miscount may occur or the count register contents may be destroyed. To change count pulse, be sure to set count mode register bit 3 to 1 and restart the timer at the same time. # (5) Operation after modulo register change The modulo register is changed when an 8-bit data memory operation instruction is executed. If the value appearing after the modulo register is changed and becomes smaller than the count register value, the count register continues counting and overflows, then restarts counting from 0. Thus, if the value after the modulo register is changed (m) and becomes smaller than the value before it was changed (n), the timer must be restarted after the modulo register is changed. # 5.5.7 Timer/event counter application - (1) Timer 0 is applied to an interval timer generating an interrupt at 50 ms intervals. - The high-order four bits of the mode register are set to 0100B and a maximum setup time of 62.5 ms is selected. - The low-order four bits of the mode register are set to 1100B. - The modulo register setup value is as follows: $$\frac{50 \text{ ms}}{244 \text{ us}} = 205 = \text{CDH}$$ Example: SEL MB15 SEL MB15 ; or CLR1 MBE MOV XA, #0CCH MOV TMOD0, XA ; Modulo is set. MOV XA, #01001100B MOV TM0, XA ; Mode is set and timer is started. El ; Interrupts is enabled. El IETO ; Timer interrupt is enabled. Remarks: In this application, the TI0 pin can be used as an input pin. (2) When the number of pulses input from the TI0 pin reaches 100, an interrupt is generated. (The pulses are active high.) - The high-order four bits of the mode register are set to 0000 and the rising edge is selected. - The low-order four bits of the mode register are set to 1100B. - The modulo register is 99 = 100 -1. Example: SEL MB15 : or CLR1 MBE XA, #100 -1 MOV MOV TMOD0, XA : Modulo is set. MOV XA. #00001100B TM0. XA MOV ΕI ΕI IET0 ; INTT0 is enabled. #### 5.6 Serial Interface ## 5.6.1 Serial interface configuration The µPD753XX has a clocked serial interface (CSI) as shown in Fig. 5.6-2. #### 5.6.2 Serial interface functions The µPD753XX serial interface includes the three modes described in (1) to (3) below. Since the serial clock line SCK and serial data bus lines SB0/SB1 enable software to determine the output level, any desired transfer format can be handled. ## (1) 3-line serial I/O mode - Three lines of serial clock SCK, serial output SO, and serial input SI - Clock synchronous 8-bit send and receive (simultaneous send and receive) - The serial transfer top can be changed between the most and least significant bits (MSB and LSB). - This mode enables the μPD753XX to be connected to the μPD7500 series, μCOM-75X family, μCOM-87 family, and various peripheral I/O devices. ## (2) SBI (serial bus interface) mode - This mode conforms to the NEC serial bus format. - Communication can be made with a number of devices by using the serial clock SCK and serial data bus SB0 or SB1 lines. - Address, command, and data can be transferred, and a hardware function for discriminating the signals is included. (See Fig. 5.6-2.) - The acknowledge, busy signal output function and the wake-up function for handshaking are included. Fig. 5.6-1 SBI System Configuration Example #### (3) 2-line serial I/O mode - Communication can be made by using the serial clock SCK and serial data bus SB0 or SB1 lines. - Communication can be made with a number of devices by using software to control the output level to the two lines. Any desired communication format can be handled. 11-3-87 Figure 5.6-3 SBI Transfer Timing Chart ## 5.6.3 Main register functions ## (1) Serial operating mode register (CSIM) The serial operation mode register (CSIM) consists of eight bits that specify the serial interface operating mode, serial clock, wake-up function, etc. CSIM is set using an 8-bit memory operation instruction. The high-order three bits of CSIM can be set bitwise using the bit name. Bit 6 enables bit test only. Data written into the bit becomes invalid. #### Example 1: To select $f_x/2^4$ for serial clock, generate a serial interrupt IRQCSI at the end of each serial transfer, and make serial transfer in the SBI mode using the SB0 pin as the serial data bus line. SEL MB15 ; or CLR1 MBE MOV XA, #10001010B MOV CSIM, XA ; CSIM 10001010B ## Example 2: To enable serial transfer conforming to the CSIM contents. SEL MB15 : or CLR1 MBE SET1 CSIE Wake-up function specification bit (WUP): ## (a) When WUP=0 IRQCSI is set each time a serial transfer ends. WUP is set to 0 during normal transfer. #### (b) When WUP = 1 WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register (SVA) value (wake-up state). When the received address is not its own, an unnecessary interrupt will not be generated. The $\overline{ACK}$ signal is not output either. The SB0 (SB1) pin is placed in a high impedance state independent of the SO the latch state. When the RESET signal is generated, all bits are cleared. Fig. 5.6-4 shows the format of the serial operation mode register. | Address | | | | | | | | | Symbol | |---------|------|-----|-----|-------|-------|-------|-------|-------|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 . | 0 | • | | FE0H | CSIE | COI | WUP | CSIM4 | CSIM3 | CSIM2 | CSIM1 | CSIM0 | CSIM | ## Serial clock selection bits (W) | CSIM1 | сѕімо | | SCK pin mode | | | |--------|---------|-----------------------------------------|--------------|-------------------------------------------|---------------| | CSIIVI | CSIIVIO | 3-line serial I/O mode | SBI mode | 2-line serial I/O mode | 3CK piil mode | | 0 | 0 | SCK pin input clock from the ex | xternal | | Input | | 0 | 1 | Timer/event counter output (TC | D) | | | | 1 | 0 | f <sub>X</sub> /2 <sup>4</sup> (262 kH. | z) | f <sub>x</sub> /2 <sup>6</sup> (65.5 kHz) | Output | | 1 | 1 | f <sub>X</sub> /2 <sup>3</sup> (524 kH | | | | The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. ## Serial interface operating mode selection bits (W) | CSIM4 | CSIM3 | CSIM2 | Operating mode | Shift register bit order | SO pin function | SI pin function | | |-------|-------|---------------------------------------------------------------|------------------------|---------------------------------------------------------|---------------------------------------------------|---------------------------------------------------|--| | V | | 0 | 0.11.0 | SIO <sub>7-0</sub> → XA<br>(transfer starts<br>at MBS) | 00/000 | QUIDOO | | | X | 0 | 1 | 3-line serial I/O mode | SIO <sub>0-7</sub> ** XA<br>(transfer starts<br>at LSB) | SO/PO2<br>(CMOS output) | SI/PO3<br>(input) | | | 0 | | , | CDI mada | SIO 45VA | SB0/PO2<br>(N-channel open drain<br>input/output) | PO3 input | | | 1 | 1 | 1 0 SBI mode SIO <sub>7-0</sub> → XA (transfer starts at MSB) | | PO2 input | SB1/PO3<br>(N-channel open drain<br>input/output) | | | | 0 | | | | SIOVA | SB1/PO2<br>(N-channel open drain<br>input/output) | PO3 input | | | 1 | | 1 | 2-line serial I/O mode | SIO <sub>7-0</sub> XA<br>(transfer starts<br>at MSB) | PO2 input | SBI/PO3<br>(N-channel open drain<br>input/output) | | (to be continued) Fig. 5.6-4 Serial Operation Mode Register Format #### Wake-up function specification bit (W) | | 0 | IRQCSI is set each time a serial transfer ends in each mode. | |-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WUP | 1 | WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register data (wake-up state). SB0 (SB1) is placed in the high impedance state | ## Coincidence signal received from address comparator (R (bit test is only enabled)) Note 1, Note 2 | Г | COL | 0 | Slave address register and shift register data mismatch. | |---|-----|---|----------------------------------------------------------| | | COI | 1 | Slave address register and shift register data match. | ## Serial interface operation enable/disable specification bit (W) Note 3 | | | Shift register operation | Serial clock counter | IRQCSI flag | SO/SB0 and SI/SB1 pins | |------|---|------------------------------|----------------------|-------------|------------------------------------------------------| | | 0 | Shift operation is disabled. | Clear | Hold | Port 0 function only | | CSIE | 1 | Shift operation is enabled. | Count operation | Can be set. | Also used for port 0 according to each mode function | # Figure 5.6-4 Serial Operation Mode Register Format (cont'd) #### Notes: - 1. COI is only valid before serial transfer starts or after it is complete. An undefined value is read during serial transfer. - 2. Data written into COI is ignored. - 3. To use PO1/SCK pin as an input port, set the following below. - Set CSIM0 and CSIM1 bits to 0. (PO1/SCK pins are set to input mode.) - Set CSIE bit to 0. (Stop the serial interface operation.) When CSIM0=CSIM1=0 and CSIE=1 or CSIM0, CSIM1≠0 and CSIE=0, PO1/SCK pins are output to high level. Remarks: (W): Data write is only enabled. (R): Data read is only enabled. ## (2) Serial bus interface control register (SBIC) The 8-bit serial bus interface control register (SBIC) consists of the serial bus state control bits and flags indicating the states of input data from serial bus. It is mainly used in the SBI mode. Fig. 5.6–5 shows the SBIC format. SBIC is set or tested by using a bit operation (manipulation) instruction. When the RESET signal is generated, all the SBIC bits are cleared. ## Cautions: - 1. SBIC cannot be set by using 4- or 8-bit memory operation instruction. - 2. In the 3- or 2-line serial I/O mode, use only the following two bits for SO latch control: - (a) Bus release trigger bit (RELT): To set SO latch - (b) Command trigger bit (CMDT): To clear SO latch - 3. For the bus release, command, acknowledge, and busy signals, see 5.6.5 (3). ## Example 1: To output command signal. SEL MB15 ; or CLR1 MBE SET1 CMDT Example 2: To test RELD and CMDD and determine the receive data type for appropriate processing. SEL MB15 SKF RELD ; RELD test BR IADRS SKT CMDD ; CMDD test BR IDATA CMD: ... ; Command transfer DATA: ... ; Data tansfer ADRS: ... ; Address transfer | Addres | | | | | | | | | | Symbol | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------|--------------|--------------|------------| | Addres | | | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | | FE2 | H BS | ΥE | ACKD | ACKE | ACKT | CMDD | RELD | CMDT | RELT | SBIC | | Bus release | trigger bit ( | W) | | | | | | | | | | RELT | RELT SO latch is set to 1 by setting the bit. It is used to output bus release signal. After SO latch is set, the bit is automatically cleared. | | | | | | | | | | | Command t | ommand trigger bit (W) | | | | | | | | | | | CMDT | SO latch is cleared by setting the bit. It is used to output a command signal. After SO latch is cleared, the bit is automatically cleared. | | | | | | | eared, the | | | | Bus release | detection f | lag (F | ?) | | | | | | | | | RELD | Clear<br>(RELE | 0=0) | | 3 | When the transfer start is indicated. When the address received after the bus is released dies not match the slave address register (SVA) data. When the RESET signal is input. | | | | | | | | Setting<br>(RELE | ~ | dition | | | ldress recei<br>s register d | | | eased matche | es the | | Command o | detection fla | g (R) | | | | | | ··· | | | | CMDD | Clear condition<br>(CMDD=0) | | | When the transfer start is indicated. When the <u>bus</u> release signal is detected. When the <u>RESET</u> signal is input. | | | | | | | | | Setting condition<br>(CMDD=1) | | | V | When the command signal is detected. | | | | | | | Acknowledg | je trigger bi | t (W) | | | | | | | | | | ACKT | Used onli<br>completion | | er transfer | | Acknowledge signal is output during one clock period of SCK immediatly after execution of the set instruction. | | | | | ĸ | | 1. ACK<br>3. To se | Remarks: 1. ACKT is automatically cleared after acknowledge signal is output. 2. ACKT cannot be cleared using software. 3. To set ACKT, set ACKE to 0. Acknowledge enable bit (R/W) | | | | | | | | | | | | 0 | | | acknowled | | utput is disa | bled (the s | ignal can be | output by se | etting the | | ACKE | | | Before tra | | Acknowledge signal is output during the ninth clock period of SCK (automatically output by presetting ACKE to 1). | | | | | | | | 1 | | After trans<br>completion | | Acknowledge signal is output during one clock period of SCK immediately after execution of the set instruction (automatically output by presetting ACKE to 1). | | | | | od of SCK | | Acknowledg | ge detection | flag | (R) | | | | | | | | | ACKD | | r con<br>KD=0 | dition<br>) | 1 . | When the <u>transfer</u> is started. When the <u>RESET</u> is input. | | | | | | | ACKD | | ing co<br>KD=1 | onditions<br>) | V | Vhen the ac | knowledge | signal is de | tected. | | | | | | | | | | | | | | | # Synchronous busy enable bit (R/W) | BSYE | 0 | Synchronous busy signal output is disabled. Synchronous busy signal output is stopped in synchronization with the SCK falling edge immediately after execution of the clear instruction. | |------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 | Synchronous busy signal is output on the $\overline{\text{SCK}}$ falling edge following an acknowledge signal. | Remarks: (R): Read is only enabled. (W): Write is only enabled. (R/W): Both read and write are enabled. Figure 5.6-5 SBIC Format Figure 5.6-6 RELT, CMDT, RELD, CMDD Operation Set after transfer completion Figure 5.6-7 ACKT Operation Figure 5.6-8 ACKE Operation When set and cleared during this period and ACKE = 0 on the SCK falling edge. #### (3) Slave address register (SVA) When the $\mu$ PD753XX is connected to the serial bus as a slave device in the SBI mode, the 8-bit slave address register (SVA) is used to set the slave address of the $\mu$ PD753XX. The SVA value is compared with received 8-bit data by the address comparator. If a match is found between them, serial operating mode register (CSIM) bit 6 (COI) is set to 1. If a match is not found when the address is received, the bus release detection flag (RELD) is cleared. When WUP = 1, IRQCSI is set only if a match is found (wake-up is detected). This interrupt request can be used to know that a communication request is sent from the master to $\mu$ PD753XX. SVA can also be used to detect an error when the $\mu PD753XX$ sends address, command, or data as a master device. (See 5.6.6.) SVA is set using an 8-bit memory operation instruction. It can only be written. When the RESET signal is generated in a mode which is not standby, the SVA value becomes undefined. #### 5.6.4 Signals in SBI mode Tables 5.6-1 and 5.6-2 list the signals used in the SBI mode. Table 5.6-1 Signals in SBI Mode (I) | Signal name | Output<br>device | Definition | Timing chart | Output<br>condition | Flag<br>influence | Explaination | |----------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | Bus release<br>signal<br>(REL) | Master | SB0 ( <u>SB1)</u> rising edge<br>when SCK = 1 | (Figure 1) | RELT is set. | <ul><li>RELD is set.</li><li>CMDD is cleared.</li></ul> | The signal is followed<br>by CMD signal output<br>indicating that the<br>send data is an address | | Command<br>signal<br>(CMD) | Master | SB0 (SB1) falling edge when SCK = 1 | (Figure 2) | CMDT is set. | • CMDD is set. | i) After REL signal is<br>output, send data<br>is an address.<br>ii) When REL signal is<br>not output, send<br>data is a command. | | Acknowledge<br>sign <u>al</u><br>(ACK) | Master/<br>Slave | Low signal output to SB0 (SB1) during one clock period of SCK after completion of serial reception | (Figure 3) | 1 ACKE = 1<br>2 ACKT is<br>set. | • ACKD is set. | Completion of reception | | Bus <u>y sign</u> al<br>(BUSY) | Slave | (Synchronous busy<br>signal)<br>Low signal output to<br>SB0 (SB1) following<br>acknowledge signal | | • BSYE = 1 | <del>-</del> | Serial reception cannot<br>be done because<br>processing is being<br>performed. | | | | (Asynchronous busy signal) Low signal output to SB0 (SB1) (except during serial transfer). It is not synchronized with SCK. | | CMDT is set. | <u>-</u> | | | Ready signal<br>(READY) | Slave | High signal output to<br>SB0 (SB1) before<br>start or after completion<br>of serial transfer | | 1 BSYE = 0<br>2 Execution<br>of SIO data<br>write instruc-<br>tion (transfer<br>start indication) | - | Serial reception can be done. | Table5.6-2 Signals in SBI Mode (II) | Signal name | Output<br>device | Definition | Timing chart | Output<br>condition | Flag<br>influence | Explanation | |--------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------| | Se <u>rial clo</u> ck<br>(SCK) | Master | Synchronous clock to output address, | (Figure 4) | Execution of<br>SIO data write<br>instruction<br>when CSIE =1<br>(serial transfer<br>start<br>indication)<br>(Note 2) | IRQCSI is<br>set (on the<br>rising edge<br>of ninth<br>clock).<br>(Note 1) | Signal output timing<br>to serial data bus | | Address<br>(A7-0) | Master | 8-bit data transferred<br>in synchronization<br>with SCK after REL<br>and CMD signals are<br>output. | (Figure 5) | | (Note 1) | Slave device address<br>value on serial bus | | Command<br>(C7-0) | Master | 8-bit data transferred in synchronization with SCK after CMD signal only is output (REL signal is not output). | (Figure 6) | | None | Indication message<br>sent to slave device | | Data<br>(D7-0) | Master<br>or<br>Slave | 8-bit data transferred<br>in synchronization<br>with SCK when neither<br>REL nor CMD signal<br>is output. | (Figure 7) | | None | Numeric data<br>processed by slave<br>or master device | Notes: 1. When WUP = 0, IRQCSI is always set on the ninth clock SCK rising edge. When WUP = 1, IRQCSI is set only when the received address matches the value in the slave address register (SVA). 2. In the BUSY state, transfer is started after the READY state is set. 5.6.5 Serial interface operation The serial interface includes the following four operating modes. - Operation stop mode - 3-line serial I/O mode - SBI mode - 2-line serial I/O mode **Table 5.6-3 Serial Interace Operation Mode** | CSIM7 | CSIM3 | CSIM2 | Operating mode | |-------|-------|-------|-------------------| | 0 | _ | _ | Operation stop | | 1 | 0 | | 3-line serial I/O | | 1 | 1 | 0 | SBI mode | | 1 | 1 | 1 | 2-line serial I/O | ## (1) Operation stop mode When CSIE = 0, the serial interface is placed in the operation stop mode. In this mode, no serial transfer is done. The operation stop mode is set when the serial interface is not used, so that the power consumption is reduced. In this mode, the shift register does not perform shift operations and can be used as a normal 8-bit register. All the P01/SCK, P02/SO/SB0, and P03/SI/SB1 pins are placed in the high impedance state and used only for the input port function. The P01/SCK pin is placed in the state listed in Table 5.6-4 according to how CSIM1 and CSIM0 are set. Table 5.6-4 CSIM1 and CSIM0 Settings | CSIM1 | CSIM0 | Serial clock | P01/SCK pin state | | |-------|-------|----------------|------------------------------------------|--| | 0 | 0 | External clock | High impedance | | | 0 | 1 | | A high level is output. | | | 1 | 0 | Internal clock | However, a serial clock is output during | | | 1 | 1 | | serial transfer. | | Note: For the serial clock, see Fig. 5.6-4. When the RESET signal is generated, the operation stop mode is set. ## (2) 3-line serial I/O mode The 3-line serial I/O mode is compatible with the mode used by the $\mu$ PD7500 series or other $\mu$ COM-75X family devices. Fig. 5.6-11 shows the 3-line serial I/O mode operation timing. Serial transfer start is indicated by executing an instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. In this mode, shift register shift operation is performed in synchronization with the serial clock $\overline{(SCK)}$ falling edge, and send data is held in the SO latch and output from the SO pin. The receive data input to the SI pin is latched in the shift register on the rising edge of $\overline{SCK}$ . Since the SO pin is used as a CMOS output and outputs the SO latch state, the SO pin output state can be handled by setting the RELT and CMDT bits. However, do not try to change it during serial transfer. The SCK pin output state can be controlled if the P01 output latch is operated in the output mode (internal clock mode), as described in 5.6.7. A serial clock can be selected from among four clocks, as listed in Table 5.6-5, by setting the mode register. Normally, shift operation is started by: - 1) Setting the operating mode and serial clock selection data in the mode register (CSIM) - 2) Setting transfer data in the shift register (SIO) (serial operation is started by executing the SIO data write instruction) Serial transfer automatically stops at the end of 8-bit transfer, and the interrupt request flag (IRQCSI) is set. Table 5.6-5 Serial CLock Selection and Application | Mode register | | Serial clock | Timing at which shift register can be | Application | | |---------------|-----------|--------------------------------|---------------------------------------|-------------------------------------------------|---------------------------------------------------------------------| | CSIM<br>1 | CSIM<br>0 | Source | Serial clock mask | read/written and serial transfer can be started | | | 0 | 0 | External SCK | Automatic mask | Only when serial transfer stops or SCK is high. | Slave CPU | | 0 | 1 | TOUT F/F | at the end of 8-bit<br>data transfer. | (Note) | Half-duplex<br>asynchronous<br>transfer (under<br>software control) | | 1 | 0 | f <sub>X</sub> /2 <sup>4</sup> | | | Medium-speed<br>serial transfer | | 1 | 1 | f <sub>X</sub> /2 <sup>3</sup> | | | High-speed<br>serial transfer | Note: The serial transfer stops in the opertaion stop mode or when the serial clock is masked after 8-bit transfer has been made. The shift register is read and written using 8-bit transfer instructions. At that time, LSB and MSB can be inverted by setting CSIM bit 2. This function enables the transfer top bit to be changed between LSB and MSB. #### Eyample: At the same time RAM data specified in the HL register pair is transfered to SIO, the SIO data is read into the accumulator, and serial transfer is started. MOV XA, @HL ; Send data is taken out of RAM. SEL MB15 ; or CLR1 MBE XCH XA, SIO ; Send data and receive data are exchanged, and transfer is started. #### Caution: The transfer top bit LSB or MSB is selected by changing the bit order in writing data into the shift register. The shift order of the shift register bit is always the same. Thus, even if the transfer top bit is changed (LSB to MSB or MSB to LSB) after data is written into the shift register, the data is transferred in the bit order specified before the transfer top bit is changed. Fig. 5.6-12 3-line I/O Mode Format #### (3) SBI mode The SBI mode enables the $\mu$ PD753XX to communicate with a number of devices by using the $\overline{SCK}$ and SB0 or SB1 lines. Figs. 5.6-13 to 5.6-15 show the timing of operations according to the type of data to be transferred. In the SBI mode, indication of serial transfer start is also given by executing the instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. Shift register shifting is made in synchronization with the serial clock (SCK) falling edge, and send data is held in the SO latch and output from the SB0/P02 or SB1/P03 pin starting at MSB. Receive data input to the SB0 or SB1 pin is latched in the shift register on the rising edge of SCK. The SB0 or SB1 pin specified for the serial data bus is used as N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off. By writing FFH into SIO and shifting it, the N-channel transistor can always be turned off during transfer. When the wake-up function specification bit (WUP) is set to 1, however, the N-channel transistor is always turned off, and FFH need not be written into SIO before reception. Fig. 5.6-13 SBI Mode Timing (Address Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.6-14 SBI Mode Timing (Command Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.6-15 SBI Mode Timing (Data Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. ## (4) 2-line serial I/O mode The 2-line serial I/O mode is used for communications using the SCK and SB0 or SB1 lines. The mode can handle any desired communication format by using software to control the SCK and SB0 or SB1 pin output levels. Fig. 5.6-16 shows the 2-line serial I/O mode timing. Serial transfer start indication is given by executing the instruction writing data into the shift register (SIO), MOV or XCH. Be sure to give start indication when CSIE = 1. Shift register shifting is done in synchronization with the falling edge of the serial clock (SCK), and send data is held in the SO latch and output from the SB0/P02 or SB1/P03 pin starting at MSB. Receive data input from the SB0 or SB1 pin is latched in the shift register on the SCK rising edge. The SB0 or SB1 pin specified for the serial data bus is used as an N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off, thus FFH is previously written into SIO. Since the SB0 or SB1 pin outputs the SO latch state, the SB0 or SB1 pin output state (high impedance or low level) can be controlled by setting the RELT and CMDT bits. However, do not change it during serial transfer. In the output mode (internal clock mode), the $\overline{SCK}$ pin output state can also be controlled by using the P01 output latch, as described in 5.6.7. Fig. 5.6-16 2-line Serial I/O Mode Timing #### 5.6.6 Error detection Since the data of the sending serial bus SB0 or SB1 is also read by the shift register SIO of the device which sends data in the SBI or 2-line serial I/O mode, a send error can be detected as described below: - (1) SIO data comparison before the start of a send and after the end of a send - If both the pieces of data do not match, it is determined that a send error occurred. - (2) Use of slave address register (SVA) Send data is also set in SVA. After the completion of a send, the COI bit (coincidence signal from the address comparator) in the serial operating mode register is tested. If the bit is set to 1, it is determined that normal sending has been performed; if 0, it is determined that a send error has occurred. ## 5.6.7 SCK pin output handling The SCK/P01 pin, which incorporates an output latch, can also produce static output by software control in addition to a normal serial clock. The number of $\overline{SCK}$ s can be set as desired by using software to control the P01 output latch (the SO/SB0, and SI/SB1 pins are controlled by setting the RELT and CMDT bits). The SCK/P01 pin output control method is described below: - (1) The serial operation mode register (CSIM) is set (SCK pin: Output mode, serial operation: Enabled). SCK is set to 1 when serial transfer stops. - (2) The P01 output latch is controlled by using bit manipulation (operation) instructions. #### Example: To output one clock pulse of SCK by using software. SEL MB15 ; or CLR1 MBE MOV XA, #10000011B ; SCK ( $f_2/2^3$ ), output mode MOV CSIM, XA CLR1 0FF0H.1 ; SCK/P01 ← 0 SET1 0FF0H.1 : SCK/P01 ← 1 Fig. 5.6-17 SCK/P01 Pin Configuration The P01 output latch is mapped in address FF0H bit 1. When the RESET signal is generated, the P01 output latch is set to 1. # Cautions: - 1. The P01 output latch must be set to 1 during normal serial transfer. - 2. Do not use "PORT0.1" to specify the P01 output latch address. Write directly the address (FF0H.1) in operand. At that time, set MBE to 0, or set MBE to 1 and MBS to 15. ## 5.6.8 Serial interface application The serial interface for each mode is explained using examples of applications. The normal serial interface communication sequence is as follows: - 1) Set transfer mode. (Set data in CSIM.) - 2) Write data into SIO and give transfer start indication. (MOV SIO, XA or XCH XA, SIO. At that time, automatic transfer start indication is given.) - 3) After checking that the serial interrupt routine or interrupt request flag (IRQCSI) is set, read receive data, and start transfer. - The SBI mode communication sequence is explained in detail in (3) below. - (1) 3-line serial I/O mode - (a) To transfer data starting at MBS using transfer clock of 262 kHz (at 4.19 MHz) (master operation). MBE Example: CLR1 MOV XA. #10000010B MOV CSIM, XA ; Transfer mode is set. MOV XA, TDATA ; TDATA is the transfer data storage address. MOV SIO, XA : Transfer data is set. : Transfer is started. #### Caution: At the second time or after, transfer can be started by setting data in SIO (MOV SIO, XA or XCH XA, SIO). In this application example, the µPD753XX SI/SB1 pin can be used for input. (b) To transfer data starting at the LSB using external clock (slave operation). (In this example, the shift register read/write function to invert the LSB and MSB is used effectively.) Example: Main routine MBE CLR1 XA, #84H MOV MOV CSIM. XA ; Serial operation stop, LSB/MSB inversion mode, external clock MOV XA. TDATA MOV SIO, XA ; Transfer data is set. : Transfer is started. ΕI **IECSI** FI Interrupt routine (MBE = 0) MOV XA, TDATA XCH XA. SIO : Receive data - send data, transfer start MOV RDATA, XA : Receive data is saved. RFTI (c) To transfer data at a high speed using a transfer clock of 524 kHz (at 4.19 MHz). Example (master) CLR1 MBE MOV XA, #10000011B ; Transfer mode is set. MOV CSIM. XA SIO. XA MOV XA, TDATA : Transfer data is set. Transfer is started. MOV SKTCLR IRQCSI LOOP: ; IRQCSI is tested. BR LOOP MOV XA. SIO : Receive data is read. ## (2) 2-line serial I/O mode The serial bus is formed and a number of devices are connected. ## Example: The example system consists of the μPD753XX as the master and μPD75104, μPD7519H, and μPD7225G connected as slaves. To form a serial bus as in this example, FFH is previously written into the shift register, a high level is output to the shift register, a high level is output to the SO pin, the output buffers are turned off, and the bus is released except when the SI and SO pins are connected for serial data output. Since the µPD7519H SO pin cannot be placed in the high impedance state, a transistor is connected for open collector output, as shown in the diagram above. At the time of data input, the transistor is turned off by previously writing 00H into the shift register. The data output timing by the microcomputers is predetermined. The serial clock is output by the master microcomputer µPD753XX; all other slave microcomputers operate on external clocks. ## (3) SBI mode An application example of serial data communication in the SBI mode is given. In the example, the $\mu$ PD753XX can operate as a master or a slave CPU. The master can also be changed by using a command. #### (a) Serial bus configuration The serial bus configuration in the application example given here assumes that the µPD753XX is connected to bus lines as one device in the serial bus. The following two μPD753XX pins are used: Serial data bus SB0 (P02/SO) and serial clock SCK (P01). Fig. 5.6-18 shows an example of a serial bus configuration. Fig. 5.6-18 Serial Bus Configuration Example ## (b) Command explanation ## Command types The application example uses the following commands: - 1) READ: - Data is transferred from slave to master. - 2) WRITE: - Data is transferred from master to slave. - 3) END: - WRITE command completion is reported to slave. - 4) STOP: - WRITE command stop is reported to slave. - 5) STATUS: - The slave state is read. - 6) RESET: - The current slave being selected is made unselected. - 7) CHGMST: The master authorization is transferred to the slave. #### Communication sequence The communication sequence between the master and slave is as follows: - 1) Communication is started by the master, which sends the address of the slave to communicate with and selects the slave (chip select). - The slave which receives the address returns ACK and communicates with the master. (The slave is placed in selected state.) - 2) Command and data are transferred between the slave selected in 1 and the master. - Since command and data are transferred point-to-point (between the master and specific slave), other slaves must be deselected. - 3) Communication terminates when the slave is deselected in either of the following cases: - When the master sends the RESET command, the selected slave is deselected. - If the master is changed by using the CHGMST command, the device changed from master to slave is deselected. Command format - The command transfer formats are shown below: - 1) READ command The READ command reads data from a given slave. The read data count ranges from one to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave Fig. 5.6-19 READ Command Transfer Format After receiving the data count, the slave returns $\overline{\mathsf{ACK}}$ if the number of $\underline{\mathsf{data}}$ bytes that can be sent is greater than the data count. If it is less than the data count, the slave does not return $\overline{\mathsf{ACK}}$ , resulting in an error. During data transfer, the slave compares the SIO contents before and after data transfer to check that data has been output to the bus normally. If the SIO contents before and after transfer do not match, the slave does not return ACK, resulting in an error. 2) WRITE, END, and STOP commands The WRITE, END, and STOP commands are used to write data into a particulary slave. The write data count ranges from 1 to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave Fig. 5.6-20 WRITE, END Command Transfer Format After receiving the data count, the slave returns ACK if the receive data store area is larger than the data count. If it is less than the data count, it does not return ACK, resulting in an error. At the termination of all data transfer, the master sends the END command to the slave. It signals that all data has been transferred normally. The slave also receives an END command before it completes all data reception. In this case, the data which has been received immediately before the END command is received becomes valid. During data sending, the master compares the SIO contents before and after data sending to check that data has been output to the bus normally. If the SO contents before and after sending do not match, the master sends the STOP command and stops data transfer. - M: Output by master - S: Output by slave Fig. 5.6-21 STOP Command Transfer Format When receiving the STOP command, the slave invalidates the 1-byte data received immediately before receiving the STOP command. 3) STATUS command The STATUS Command Transfer Format - M: Output by master - S: Output by slave Fig. 5.6-22 STATUS Command Status Format Fig. 5.6-23 shows the format of the status returned by the slave. Fig. 5.6-23 STATUS Command Status Format To send status data, the slave compares the contents before and after sending status data. If they do not match, the slave does not return ACK, resulting in an error. #### 4) RESET command The RESET command is used to cause the currently selected slave to be selected. When the RESET command is issued, all slaves can be deselected. M: Output by master S: Output ba slave Fig. 5.6-24 RESET Command Transfer Format #### 5) CHGMST command The CHGMST command transfers the master authorization to the currently selected slave. M: Output by master S: Output by slave Fig. 5.6-25 CHGMST Command Transfer Format When receiving the CHGMST command, the slave decides whether or not it can receive the master authorization, and returns either of the following data to the master: - OFFH: Master change is enabled. - 00H : Master change is disabled. When transferring data, the slave compares the SIO contents before and after data transfer. If they do not match, the slave does not return $\overline{ACK}$ , resulting in an error. If no error occurs, the master serves as a slave after 0FFH data sending is complete. If no error occurs, the slave serves as the master after 0FFH data sending is completed. #### Error occurrence When a communication error occurs, the master and slave operate as explained below: The slave informs the master of error occurrence by returning no ACK. When an error occurs, the status bit (bit 2) indicating error occurence is set to 1 and all command processing being performed is cancelled.\_\_\_\_\_ After completing the sending or receiving of one byte, the master checks whether or not $\overline{ACK}$ is returned from slave. If $\overline{ACK}$ is not returned from slave within a given period after sending or receiving is completed, the master decides that an error has occurred and outputs a dummy $\overline{ACK}$ signal. Fig. 5.6-26 Master and Slave Operation when Error Occured The following errors are possible: - Errors that may occur in the slave - 1) Command transfer format is erroneous. - 2) Undefined command is received. - 3) The number of data bytes to be transferred (data count) is insufficient during READ command execution, - 4) Data storage area is insufficient during WRITE command execution. - 5) When READ, STATUS, or CHGMST command data is sent, data changes. When any error in 1) or 5) occurs, no ACK is returned. - Errors that may occur in the master When WRITE command data is sent, if data changes, STOP command is sent to the slave. #### 5.7 LCD Controller/Driver 5.7.1 LCD controller/driver configuration The $\mu PD753XX$ incorporates a display controller which generates segment and common signals according to the display data memory contents and incorporates segment and common drivers which can drive the panel directly. Fig. 5.7-1 shows the LCD controller/driver configuration. Fig. 5.7-1 LCD Controller/Driver Block Diagram #### 5.7.2 LCD controller/driver functions The µPD753XX LCD controller/driver functions are as follows: - (a) Display data memory is read automatically by DMA operation and segment and common signals are generated. - (b) Display mode can be selected from among the following five. - 1) Static - 2) 1/2 duty (1/2 bias) - 3) 1/3 duty (1/2 bias) - 4) 1/3 duty (1/3 bias) - 5) 1/4 duty (1/3 bias) - (c) A frame frequency can be selected from among four in each display mode. - (d) A maximum of 32 segment signal output pins (S0-S31) and four common signal output pins (COM0 COM3). - (e) The segment signal output pins (S24-S27 and S28-S31) can be changed to the output ports (BP0-BP3 and BP4-BP7) in 4-pin units. - (f) Split-resistor can be incorporated to supply LCD drive power. (Mask option) - Various bias laws and LCD drive voltage can be handled. - When display is off, current flow to the split resistor is cut. - (g) Display data memory not used for display can be used for normal data memory. - (h) It can also operate by using the subsystem clock. Table 5.7-1 lists the maximum number of picture elements that can be displayed in each display mode. Table 5.7-1 Maximum Number of Displayed Picture Elements | Bias law | Time division | Used COMMON signals | Maximum number of picture elements | |----------|---------------|---------------------|--------------------------------------| | | Static | COM0 (COM1, 2, 3) | 32 (segment 32 x common 1) (Note 1) | | 1/2 | 2 | COM0, 1 | 64 (segment 32 x common 2) (Note 2) | | | 3 | 00140 1 0 | 96 (segment 32 x common 3) (Note 3) | | 1/3 | 3 | COM0, 1, 2 | 96 (segment 32 x common 3) (Note 3) | | | 4 | COM0, 1, 2, 3 | 128 (segment 32 x common 4) (Note 4) | Note 1: 4 digits (eight segment signal/digit) on LCD panel (8. display). Note 2: 8 digits (four segment signal/digit) on LCD panel (B. display). Note 3: 10 digits (three segment signal/digit) on LCD panel (8. display). Note 4: 16 digits (two segment signal/digit) on LCD panel (B. display). ## 5.7.3 Display mode register The display mode register (LCDM) consists of eight bits to specify the display mode, LCD clock, frame frequency, segment or bit port output, and display output on/off control. LCDM is set by using 8-bit memory operation instruction. Only bit 3 (LCDM3) can be set and cleared by using bit operation (manipulation) instructions. When the RESET signal is generated, all the LCDM bits are cleared. | Address<br>7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Symbol | |--------------|-------------|-------|-------|------------|---------------|-------------|-------|-------|--------| | F8CH | LCDM7 | LCDM6 | LCDM5 | LCDM4 | LCDM3 | LCDM2 | LCDM1 | LCDM0 | LCDM | | Display Mod | e Selection | | | | | | | | • | | LCDM3 | LCDM2 | LCDM1 | LCDM0 | Time divis | ion value | Bias method | П | | | | 0 | Х | Х | Х | [ | Display off ( | Note) | | | | | 1 | 0 | 0 | 0 | 4 | | 1/3 | | | | | 1 | 0 | 0 | 1 | 3 | | 1/3 | | | | | 1 | 0 | 1 | 0 | 2 | | 1/2 | | | | 3 Static Undefined 1/2 Note: All segment signals are unselected. Other than the above 0 0 #### LCD Clock Selection 1 | LCDM5 | LCDM4 | LCDMCL | |-------|-------|-----------------------------------------| | 0 | 0 | f <sub>W</sub> /2 <sup>9</sup> (64 Hz) | | 0 | 1 | f <sub>W</sub> /2 <sup>8</sup> (128 Hz) | | 1 | 0 | f <sub>W</sub> /2 <sup>7</sup> (256 Hz) | | 1 | 1 | f <sub>W</sub> /2 <sup>6</sup> (512 Hz) | Caution: LCDCL is supplied only when the watch timer operates. To use the LCD controller, bit 2 of watch mode register WM should be set to 1. Segment and Bit Port Output Change Specification | LCDM7 | LCDM6 | S24/S27 | S28/S31 | Number of segment output pins | Number of bit port output pins | |-------|-------|-----------------|-----------------|-------------------------------|--------------------------------| | 0 | 0 | Segment output | Segment output | 32 | 0 | | 0 | 1 | Segment output | Bit port output | 28 | 4 | | 1 | 0 | Bit port output | Segment output | 28 | 4 | | 1 | 1 | Bit port output | Bit port output | 24 | 8 | ## Frame Frequency (Hz) | Display duty cycle | f <sub>W</sub> /2 <sup>9</sup> (64 Hz) | f <sub>W</sub> /2 <sup>8</sup> (128 Hz) | f <sub>W</sub> /2 <sup>7</sup> (256 Hz) | f <sub>W</sub> /2 <sup>6</sup> (512 Hz) | | |--------------------|----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|--| | Static | 64 | 128 | 256 | 512 | | | 1/2 | 32 | 64 | 128 | 256 | | | 1/3 | 21 | 43 | 85 | 171 | | | 1/4 | 16 | 32 | 64 | 128 | | When $f_w = 32.768 \text{ kHz}$ $f_W$ : Input clock to watch timer ( $f_X/128$ or $f_{XT}$ ) Fig. 5.7-2 Display Mode Register Format #### 5.7.4 Display control register The display control register controls LCD drive as follows: - Enables or disables common and segment output. - Cuts current flow to the split resistor for the LCD power supply. - Enables or disables output of the synchronizing clock (LCDCL) and synchronizing signal (SYNC) to the controller/driver for external segment signal extension. LCDCL is set by using a 4-bit memory operation instruction. When the RESET signal is generated, the display control register is cleared. | Address | | | | | Symbol | |---------|---|-------|---|-------|--------| | _ | 3 | 2 | 1 | 0 | _ | | F8EH | 0 | LCDC2 | 0 | LCDC0 | LCDC | | LCDC0 | 0 | 1 | | |--------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | LCDM3 | х | 0 | 1 | | COM0-3 | Low level is output (display off). | Common signal corresponding to the display mode is output. | Common signal corresponding to the display mode is output. | | S0-S23 | Low level is output | Segment signal corresponding to the | Segment signal corresponding to the | | S24-S31 segment specification pins | (display off). | display mode is output (no-selection level output, display off). | display mode is output (display on). | | S24-S31 bit port specification pins | Bit 0 for the corres-<br>ponding display<br>data memory is<br>output (bit port<br>function). | Bit 0 for the corresponding display data memory is output (bit port function). | Bit 0 for the corresponding display data memory is output (bit port function). | | Power supply to<br>split resistor<br>(BIAS pin output) | Off<br>(high impedance) | On<br>(high level) | On<br>(high level) | Note 1: ( ): When internal split register for LCD drive power supply is not contained. LCDCL and SYNC Signal Output Enable/Disable Specification Bit | LCDCL2 | 0 | LCDCL and SYNC signal output is disabled. | |--------|---|-------------------------------------------| | LODGLZ | 1 | LCDCL and SYNC signal output is enabled. | Note: LCDCL, SYNC signal output are provided for future system extension. Disable signal output at present. Fig. 5.7-3 Display Control Register Format Display data memory #### 5.7.5 Display data memory The display data memory is mapped in 1E0H-1FFH. The display data memory is an area read by the LCD controller/driver, which performs DMA operation independently of CPU operation. The LCD controller controls the segment signals according to data in the display data memory. When S24-S31 are used for bit ports, bit 0 of the data written into display data memory addresses 1F8H-1FFH is output from each bit port output pin. The area not used for LCD display or ports can be used for normal data memory. The display data memory is handled in 1- or 4-bit units. It cannot be handled in 8-bit units. Fig. 5.7-5 shows the relationship between the display data memory bits and segment output/bit port output. Fig. 5.7-4 Data Memory Map Fig. 5.7-5 Relationship between Display Data Memory and Common Segment #### 5.7.6 Common and segment signals Each picture element of the LCD panel goes on when the potential difference between its corresponding common signal and segment signal reaches or exceeds a given voltage (LCD drive voltage VLCD). It goes off when the potential difference falls below VLCD or reaches 0V. Since deterioration occurs when DC potential is maintained as the common and segment signals, the LCD panel is driven by AC. (1) Common signals The common signals become the selection timing in the order listed in Table 5.7-2 according to the set time division number, and repetitive operation is performed by using them as one period. In the static mode, COM0 to COM3 output the same signal. In division by 2, neither COM2 nor COM3 pin should be connected. In division by 3, do not connect the COM3 pin. Table 5.7-2 COM Signals | COM signal | | | | | |----------------------|------|------|------------------------|------------------------| | Time division number | СОМО | COM1 | COM2 | СОМЗ | | Static | | | | • | | 2 | | | No connection required | No connection required | | 3 | | | | No connection required | | 4 | | | | | #### (2) Segment signals There are 32 segment signals corresponding to 32 locations of the display data area (1E0H-1FFH) of the data memory. Bits 0 to 3 of each location are automatically read in synchronization with the selection timing for COM0 to COM3 respectively. If the bit is set to 1, it produces the segment selection voltage; if 0, the bit produces the no-selection voltage output from the corresponding segment pin (S0-S31). Thus, check the display patterns formed according to the combinations of the LCD panel front electrode (corresponding to segment signal) and rear electrode (corresponding to common signal). Then, on a one-to-one basis, write into the display area the bit data which corresponds to the pattern to be displayed. Display data area bits 1 to 3 in the static mode, bits 2 and 3 in the division by 2 mode, and bit 3 in the division by 3 mode are not accessed and can be used for purposes other than display. #### (3) Common and segment signal output waveforms Tables 5.7-3 to 5.7-5 list voltages output to the common and segment signals. +VLCD/-VLCD on voltage is applied only when both signals become selection voltages; otherwise, the off voltage is applied. Table 5.7-3 LCD Drive Voltage (Static) | Segment signal | Selection | No-selection | |-----------------------------------|--------------------------------------|-----------------------------------| | Common signal | V <sub>LC0</sub> /V <sub>SS</sub> | V <sub>SS</sub> /V <sub>LC0</sub> | | V <sub>SS</sub> /V <sub>LC0</sub> | +V <sub>LCD</sub> /-V <sub>LCD</sub> | 0V/0V | Table 5.7-4 LCD Drive Voltage (1/2 Bias Law) | Se | gment signal | Selection | No-selection | |-----------------------|-------------------------------------|----------------------------------------------|----------------------------------------------| | Common signal<br>COMm | Sn | $V_{LC0}/V_{SS}$ | V <sub>ss</sub> /V <sub>LC0</sub> | | Selection | V <sub>SS</sub> /V <sub>LC0</sub> | +V <sub>LCD</sub> /-V <sub>LCD</sub> | 0V/0V | | No-selection | V <sub>LC1</sub> = V <sub>LC2</sub> | +1/2 V <sub>LCD</sub> /-1/2 V <sub>LCD</sub> | -1/2 V <sub>LCD</sub> /+1/2 V <sub>LCD</sub> | Table 5.7-5 LCD Drive Voltage (1/3 Bias Law) | Se | gment signal | Selection | No-selection | |-----------------------|------------------------------------|----------------------------------------------|----------------------------------------------| | Common signal<br>COMm | Sn | V <sub>LC0</sub> /V <sub>SS</sub> | V <sub>LC2</sub> /V <sub>LC1</sub> | | Selection | V <sub>SS</sub> /V <sub>LC0</sub> | +V <sub>LCD</sub> /-V <sub>LCD</sub> | +1/3 V <sub>LCD</sub> /-1/3 V <sub>LCD</sub> | | No-selection | V <sub>LC1</sub> /V <sub>LC2</sub> | +1/3 V <sub>LCD</sub> /–1/3 V <sub>LCD</sub> | +1/3 V <sub>LCD</sub> /–1/3 V <sub>LCD</sub> | Figs. 5.7-6 to 5.7-8 shows the common signal waveforms. Fig. 5.7-9 shows the common and segment signal voltages and phases. Fig. 5.7-7 Common Signal Waveform (1/2 Bias Law) Fig. 5.7-8 Common Signal Waveform (1/3 Bias Law) Fig. 5.7-9 Common and Segment Signal Voltages and Phases Fig. 5.7-9 Common and Segment Signal Voltages and Phases (cont'd) 5.7.7 Supply of LCD drive power $V_{LC0}$ , $V_{LC1}$ , and $V_{LC2}$ In the $\mu$ PD753XX, a split resistor can be incorporated in the $V_{LC0}$ - $V_{LC2}$ pins for the LCD drive power supply. According to the bias law, the LCD drive power can be supplied without an external split resistor. The $\mu$ PD753XX also includes the BIAS pin to deal with various LCD drive voltages. The BIAS and $\rm V_{LCO}$ pins are connected externally. Table 5.7-6 lists proper LCD drive power supply values based on the static, 1/2, and 1/3 bias laws. Table 5.7-6 LCD Drive Power Supply Values | LCD<br>drive power | No bias<br>(static mode) | 1/2 | 1/3 | | |--------------------|--------------------------|-------------------------------|----------------------|--| | V <sub>LC0</sub> | V <sub>LCD</sub> | V <sub>LCD</sub> | V <sub>LCD</sub> | | | V <sub>LC1</sub> | 2/3 V <sub>LCD</sub> | 1/2 \/ (Note 1) | 2/3 V <sub>LCD</sub> | | | V <sub>LC2</sub> | 1/3 V <sub>LCD</sub> | 1/2 V <sub>LCD</sub> (Note 1) | 1/3 V <sub>LCD</sub> | | | V <sub>LC3</sub> | 0V | ٥٧ | 0V | | Note 1: When 1/2 bias is used, the VLC1 and VLC2 pins must be connected externally. Note 2: When the BIAS and $V_{LCD}$ pins are not connected, $V_{LCD}$ = 3/5 $V_{DD}$ (when split resistor is incorporated). When the BIAS and $V_{LCD}$ pins are connected, $V_{LCD}$ = $V_{DD}$ . In Fig. 5.7-10, (a) to (c) show LCD drive power supply examples according to Table 5.7-6. Fig. 5.7-11 (d) shows an example in which external resistor is connected to the LCD drive voltage pins (V<sub>I,CO</sub>-V<sub>I,CO</sub>) and BIAS pin, and internal split resistor is fine- Current flow through the split resistor can also be cut by clearing display control register bit 0 (LCDC0). This LCD power on/off control is also useful to prevent DC voltage from being applied to LCD when the LCD clock is stopped by execution of a STOP instruction and when the watch timer operates using the main system clock. That is, display control register bit 0 (LCDC0) is cleared and all LCD drive power sources are placed in the same potential VSS immediatly before the STOP instruction is executed, thereby suppressing the potential difference between the LCD electrodes even if the LCD clock is stopped. When the watch timer operates using the subsystem clock, the LCD display can still be used. (a) 1/3 bias law and static mode display (b) 1/2 bias law (c) 1/3 bias law and static display mode In example (a), $V_{DD}$ = 5V and LCD drive voltage $V_{LCD}$ = 3V. In example (b), $V_{DD}$ = 5V and $V_{LCD}$ = 2.5V. In example (c), $V_{DD}$ = 5V and $V_{LCD}$ = 5V. Fig. 5.7-10 LCD Drive Power Connection Examples (when split resistor is incorporated) ## (a) Static display mode (Note) ## (b) Static display mode (c) 1/2 bias method (d) 1/3 bias method In example (a), $V_{DD}$ = 5V and LCD drive voltage $V_{LCD}$ = 5V. In example (b) and (d), $V_{DD}$ = 5V and LCD drive voltage $V_{LCD}$ = 3V. In example (c), $V_{DD}$ = 5V and $V_{LCD}$ = 2.5V. Note: Be sure to set LCDC0 to 1 (also during the standby mode) Fig. 5.7-11 LCD Drive Power Connection Examples (when split resistor is corporated externally) #### 5.7.8 Display mode ## (1) Static display example Fig. 5.7-14 shows connection of a static 4-digit LCD panel having the display pattern shown in Fig. 5.7-13, the μPD753XX segment signals (S0-S31), and the common signal (COM0). In this example, 123.4 is displayed. The contents of the display data memory (addresses 1E0H-1FFH) correspond to the display pattern. Here, 3. (3.) at the second digit position is taken as an example. It is necessary to output selection and no-selection voltages as shown in Fig. 5.7-12 to the S8-S15 pins at the COM0 common signal timing according to the display pattern shown in Fig. 5.7-13. | Segment | S8 | S9 | S10 | S11 | S12 | S13 | S14 | S15 | |---------|-----------|-----------|-----------|-----------|--------------|-----------|--------------|-----------| | COM0 | Selection | Selection | Selection | Selection | No-selection | Selection | No-selection | Selection | Fig. 5.7-12 Selection/Non-selection Voltages of S8-S15 Pins (Static Display Examples) This shows that the bit 0 string of display data memory addresses 1E8H-1EFH corresponding to S8-S15 needs to be set to 11110101. Fig. 5.7-15 shows the S11, S12, and COM0 LCD drive waveforms. This shows that alternating current square wave of $+V_{LCD}/-V_{LCD}$ that is LCD on level is generated when S11 becomes the selection voltage at the selection timing of COM0. Since the same waveform as COM0 is output to COM1 to COM3, the drive capability can be increased by connecting COM0, COM1, COM2, and COM3. Fig. 5.7-13 Static Mode LCD Display Pattern and Electrode Connection Fig. 5.7-14 Static LCD panel Connection Example Fig. 5.7-15 Static LCD Drive Waveform Example ## (2) Division by 2 display example Fig. 5.7-18 shows connection of the division by 2 mode 8-digit LCD panel having the display pattern shown in Fig. 5.7-17, the $\mu$ PD753XX segment signals (S0-S31), and the common signals (COM0 and COM1). In the example, 123456.78 is displayed. The contents of the display data memory (addresses 1E0H-1FFH) correspond to the display pattern. Here, 6. ( £.) at the third digit position is taken as an example. It is necessary to output the selection and no-selection voltages as shown in Fig. 5.7-16 to the S8-11 pins at the timing of the COM0 and COM1 common signal according to the display pattern shown in Fig. 5.7-17. | Segment | S8 | S9 | S10 | S11 | |---------|-----------|--------------|-----------|-----------| | COM0 | Selection | No-selection | Selection | Selection | | COM1 | Selection | Selection | Selection | Selection | Fig. 5.7-16 Selection/Non-selection Voltages of S8-S11 Pins (Division by 2 Mode Display Examples) This shows that for example, the display data memory address 1F9H bits corresponding to S9 need to be set to xx10. Fig. 5.7-19 shows an LCD drive waveform example among S9 and common signals. This shows an alternating current square wave of $+V_{LCD}/-V_{LCD}$ that is the LCD on level being generated when S9 is the selection voltage at the COM1 selection timing. Fig. 5.7-17 Division by 2 Mode LCD Display Pattern and Electrode Connection X: Any data can be stored at any time because of division by 2 display. Fig. 5.7-18 Division by 2 LCD Panel Connection Example Fig. 5.7-19 Division by 2 LCD Drive Waveform Example (1/2 Bias Law) ## (3) Division by 3 display example Fig. 5.7-22 shows connection of a division by 3 mode 6-digit LCD panel having the display pattern shown in Fig. 5.7-21, the $\mu$ PD753XX segment signals (S0-S29), and the common signals (COM0-COM2). In this example, 123456.7890 is displayed. The contents of the display data memory (addresses 1E0H-1FDH) correspond to the display pattern. Here, 6. (6.) at the 5-digit position is taken as an example. It is necessary to output the selection and no-selection voltages Here, 6. ( 6.) at the 5-digit position is taken as an example. It is necessary to output the selection and no-selection voltages as shown in Fig. 5.7-20 to the S12-S14 pins at the COM0-COM2 common signal timings according to the display pattern shown in Fig. 5.7-21. | Segment | S12 | S13 | S14 | |---------|--------------|-----------|-----------| | COM0 | No-selection | Selection | Selection | | COM1 | Selection | Selection | Selection | | COM2 | Selection | Selection | _ | Fig. 5.7-20 Selection/Non-selection Voltages of S12-S14 Pins (Division by 3 Mode Display Examples) This shows that the bits at display data memory address 1ECH corresponding to S12 need to be set to x110. Fig. 5.7-23 and 5.7-24 show LCD drive waveforms among S12 and common signals (1/2 and 1/3 bias law). These shown an alternating current square wave of $+V_{LCD}'-V_{LCD}$ that is the selection voltage at the COM1 selection timing and S12 is the selection voltage at the COM2 selection timing. Fig. 5.7-21 Division by 3 Mode LCD Display Pattern and Electrode Connection X: Any data can be stored because the LCD panel does not have a corresponding segment. X : Any data can be stored because of division by 3 display. Fig. 5.7-22 Division by 3 LCD Panel Connection Example Fig.5.7-23 Division by 3 LCD Drive Waveform Example (1/2 Bias Law) Fig.5.7-23 Division by 3 LCD Drive Waveform Example (1/3 Bias Law) #### (4) Division by 4 Display Example shown in Fig. 5.7-26. Fig. 5.7-27 shows connection of the division by 4 mode 16-digit LCD panel having the display pattern shown in Fig. 5.7-26, the µPD753XX segment signals (S0-S31), and the common signals (COM0-COM3). In this example, 123456.7890123456 is displayed. The contents of the display data memory (addresses 1E0H-1FFH) correspond to the display pattern. Here, 6. (£), at the 11-digit position is taken as an example. It is necessary to output the selection and no-selection voltages as shown in Fig. 5.7-25 to the S20 and S21 pins at the COM0-COM3 common signal timing according to the display pattern | Segment | S20 | S21 | |---------|--------------|-----------| | COM0 | Selection | Selection | | COM1 | No-selection | Selection | | COM2 | Selection | Selection | | СОМЗ | Selection | Selection | Fig. 5.7-25 Selection/Non-selection Voltage of S20 and S21 (Division by 4 Mode Display Examples) This shows that the bits at display data memory address 1F4H corresponding to S20 need to be set to 1101. Fig. 5.7-28 shows LCD drive waveforms for S20, COM0, and COM1 signals. (Waveforms for COM2 and COM3 are omitted because of drawing space.) This shows an alternating current square wave of +V<sub>LCD</sub>/-V<sub>LCD</sub> that is the LCD on level being generated when S20 becomes the selection voltage at the COM0 selection timing. Fig. 5.7-26 Division by 4 Mode LCD Display Pattern and Electrode Connection Fig. 5.7-27 Division by 4 LCD Panel Connection Example Fig. 5.7-28 Division by 4 LCD Drive Waveform Example (1/3 Bias Method) #### 5.8 Bit Sequential Buffer - 16 Bits The bit sequential buffer is a special data memory for bit manipulation. Bit manipulation can be easily performed by changing address and bit specification in sequence. The buffer is useful for bitwise processing of long data. The data memory consists of 16 bits, pmem.@L addressing of bit manipulation is enabled; indirect bit specification can be made by using the L register . Simply by incrementing or decrementing the L register in a program loop, processing can be performed while the specified bits are being moved in sequence. Fig. 5.8-1 Bit Sequential Buffer Format #### Remarks: In pmem.@L addressing, specified bits are moved according to the L register. Data can also be handled in direct addressing. The 1-, 4-, and 8-bit direct addressing modes and pmem.@L addressing mode can be used in combination for continuous input and output of 1-bit data. In 8-bit manipulation, BSB0 and BSB2 are specified, and data is handled every high-order eight and low-order eight bits. To output 16-bit data in BUFF 1 and BUFF2 from port 3 bit 0 serially. | | CLR1 | MBE | | |--------|------|------------|--------------------------------| | | MOV | XA, BUFF1 | | | | MOV | BSB0, XA | ; BSB0 and BSB1 are set. | | | MOV | XA, BUFF 2 | | | | MOV | BSB2, XA | ; BSB2 and BSB3 are set. | | | MOV | L, #0 | | | LOOP: | SKT | BSB0, @L | ; BSB-specified bit is tested. | | | BR | LOOP1 | | | | NOP | | ; Dummy (timing adjustment) | | | SET1 | PORT3.0 | ; Port 3 bit 0 is set. | | | BR | LOOP2 | | | LOOP1: | CLR1 | PORT3.0 | ; Port 3 bit 0 is cleared. | | | NOP | | ; Dummy (timing adjustment) | | | NOP | | | | LOOP2: | INCS | L | ; L=- L+1 | | | BR | LOOP | | | | | RET | | ### **CHAPTER 6 INTERRUPT FUNCTION** The µPD753XX contains six vectored interrupt sources and two testable inputs for versatile application. The µPD753XX interrupt control circuit has the following features to enable very high-speed interrupt service: - (a) Whether or not interrupts can be acknowledged can be controlled by using enable flag (IEXXX). - (b) The interrupt service start address and MBE during interrupt service can be set as desired by using a vector table. Starting the actual interrupt service program is fast. - (c) Interrupt request flag (IRQXXX) can be tested and cleared. Interrupt occurrence can be checked by using software. - (d) The standby mode (STOP or HALT) can be released by making an interrupt request. A backup release source is available by using the interrupt enable flag. ## 6.1 Interrupt Control Circuit Configuration Fig. 6.1-1 shows configuration of the interrupt control circuit. The hardware devices are mapped in data memory. Fig. 6.1-1 Interrupt Control Circuit Block Diagram # 6.2 Interrupt Source Types and Vector Table Table 6.2-1 lists the types of interrupt sources for the μPD753XX. Fig. 6.2-1 shows the interrupt vector table. **Table 6.2-1 Interrupt Source Types** | | Interrupt source | Internal<br>/external | Interrupt priority (Note 1) | Vectored interrupt request signal (vector table address) | |--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------|-----------------------------|----------------------------------------------------------| | INTBT<br>(reference | time interval signal from basic interval timer) | Internal | 1 | VRQ1 (0002H) | | INT4 (both rising and falling edge detection) | | External | : | | | INT0 | (selection of rising or falling edge detection) | External | 2 | VRQ2 (0004H) | | INT1 | | External | 3 | VRQ3 (0006H) | | INTCSI<br>(serial data transfer end signal) | | Internal | 4 | VRQ4 (0008H) | | ١, | ee signal between programmable timer/<br>unt register and modulo register) | Internal | 5 | VRQ5 (000AH) | | INT2<br>(rising edge detection of input to INT2 pin or falling edge<br>detection of any input to KR0-KR7) (Note 2) | | External | Testable input signals (IR | Q2 and IRQW are set) | | INTW<br>(signal from | n watch timer) | Internal | | | Note 1: The interrupt priority indicates the priority given to each interrupt when more than one interrupt request occurs at the same time. Note 2: For details of INT2, see 6.3 (2). #### Address | 002H | MBE | 0 | 0 | 0 | INTBT/INT4 start address (high-order four bits) | |------|-----|---|---|---|-------------------------------------------------| | | | | | | INTBT/INT4 start address (low-order eight bits) | | 004H | MBE | 0 | 0 | 0 | INTO start address<br>(high-order four bits) | | | | | | | INT0 start address<br>(low-order eight bits) | | 006H | MBE | 0 | 0 | 0 | INT1 start address<br>(high-order four bits) | | | | | | | INT1 start address<br>(low-order eight bits) | | H800 | MBE | 0 | 0 | 0 | INTCSI start address<br>(high-order four bits) | | | | | | | INTCSI start address (low-order eight bits) | | 00AH | MBE | 0 | 0 | 0 | INTT0 start address<br>(high-order four bits) | | | | | | | INTT0 start address<br>(low-order eight bits) | Fig. 6.2-1 Interrupt Vector Table (a) µPD75304 | Address | | | | | |---------|-----|---|---|----------------------------------------------------| | 002H | MBE | 0 | 0 | INTBT/INT4 start address (high-order five bits) | | | | | | INTBT/INT4 start address<br>(low-order eight bits) | | 004H | MBE | 0 | 0 | INT0 start address<br>(high-order five bits) | | - | | | | INT0 start address<br>(low-order eight bits) | | 006H | MBE | 0 | 0 | INT1 start address<br>(high-order five bits) | | | | | | INT1 start address<br>(low-order eight bits) | | 008H | MBE | 0 | 0 | INTCSI start address (high-order five bits) | | | | | | INTCSI start address<br>(low-order eight bits) | | 00AH | MBE | 0 | 0 | INTT0 start address<br>(high-order five bits) | | | | | | INTT0 start address<br>(low-order eight bits) | Fig. 6.2-1 Interrupt Vector Table (b) μPD75306, μPD75308 | Address | | | | |---------|-----|---|-------------------------------------------------| | 002H | MBE | 0 | INTBT/INT4 start address (high-order six bits) | | | | | INTBT/INT4 start address (low-order eight bits) | | 004H | MBE | 0 | INT0 start address<br>(high-order six bits) | | | | | INT0 start address<br>(low-order eight bits) | | 006H | MBE | 0 | INT1 start address<br>(high-order six bits) | | | | - | INT1 start address<br>(low-order eight bits) | | H800 | MBE | 0 | INTCSI start address<br>(high-order six bits) | | | | | INTCSI start address<br>(low-order eight bits) | | 00AH | MBE | 0 | INTT0 start address<br>(high-order six bits) | | | | | INTT0 start address<br>(low-order eight bits) | Fig. 6.2-1 Interrupt Vector Table (c) $\mu$ PD75312, $\mu$ PD75316 The interrupt priority in Table 6.2-1 indicates the interrupt execution order when a number of interrupt requests occur at the same time or are held. The interrupt service start addresses and MBE setup values during interrupt service are written into the vector table. The vector table is set by using an assembler pseudo-instruction (VENTn). Example: To set INTBT/INT4 in vector table Caution 1: The vector table address specified in VENTn (n=1-5) becomes 2n address. Caution 2: Always set RBE to 0 in VENTn. Example: To set INTBT/INT4 and INTT0 in vector table. VENT1 MBE=0, RBE=0, GOTOBT VENT5 MBE=0, RBE=0, GOTOT0 ## 6.3 Hardware Devices of Interrupt Control Circuit (1) Interrupt request and enable flags The interrupt request flag (IRQXXX) is set to 1 when a given interrupt request occurs; it is automatically cleared when interrupt service is executed. Although IRQBT and INT4 share the vector address, they differ in clear operation. (See 6.6.) An interrupt enable flag (IEXXX) is provided for each interrupt request flag. An interrupt is enabled when the corresponding interrupt enable flag is set to 1 and disabled when the flag is set to 0. When the interrupt request flag is set, and the interrupt enable flag enables an interrupt, a vectored interrupt request (VRQn) occurs. This signal is also used to release the standby mode. The interrupt request and enable flags are handled by using the bit manipulation and 4-bit memory operation instructions. The flags can be directly handled by using the bit manipulation instruction regardless of how MBE is set. The interrupt enable flags are handled by using the EI IEXXX and DI IEXXX instructions. Normally, the interrupt request flags are tested by using the SKTCLR instruction. Example: EI IEO ; INTO is enabled. DI IE1 ; INT1 is disabled. SKTCLR IRQCSI ; If IRQCSI is set to 1, skip and clear. If the interrupt request flag is set by using the instruction, a vectored interrupt is executed as if an interrupt occured although it did not actually occurs. When the RESET signal is generated, the interrupt request and enable flags are cleared, and all interrupts are disabled. Table 6.3-1 Interrupt Request and Enable Flags | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | IRQBT | Is set by reference time interval signal generated by the basic interval timer | IEBT | | IRQ4 | Is set when either the rising or falling edge of the INT4/P00 pin input signal is detected. | IE4 | | IRQ0 | Is set when the INT0/P10 pin input signal edge is detected. Detected edge is selected among rising and falling edges by using the INT0 mode register (IM0). | IE0 | | IRQ1 | Is set when the edge of the INT1/P11 pin input signal is detected. Detected edge is selected from rising and falling edges by using the INT1 mode register (IM1). | IE1 | | IRQCSI | Is set by serial data transfer end signal on serial interface. | IECSI | | IRQT0 | Is set by coincidence signal from timer/event counter 0. | IET0 | Table 6.3-1 Interrupt Request and Enable Flags (cont'd) | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | IRQW | Is set by signal from the watch timer. | IEW | | IRQ2 | Is set when the rising edge of the INT2/P12 pin input signal is detected or the falling edge of any input to the KR0/P60 to KR7/P73 pins is detected. | IE2 | (2) Noise eliminator and edge detection mode registers. Figs. 6.3-1 and 6.3-2 show the relationship of INT0 and INT1, INT2 and KR0-KR7 pins, respectively, within the interrupt control circuit. They are used for inputting external interrupts in cases where noise can be eliminated by the sampling clock and the detected edge can be selected. Any pulse narrower than the sampling clock is determined to be a noise pulse and is eliminated by the noise eliminator. A pulse twice as wide (or more) as the sampling clock is acknowledged as a valid interrupt signal. For INT0 the sampling clock can be changed to two stages. Note that when the INTO pin is used for P10 (port pin), the signal is also input via the noise eliminator. Caution: Since INT0 sampling uses clock, INT0 does not operate at standby mode. IRQ2 is set in either of the following modes: - (a) When the rising edge of INT2 pin input is detected, IRQ2 is set. - (b) When the falling edge of any input to KR0-KR7 pins is detected: When the falling edge of any input to pins selected among KR0-KR7 by using the edge detection mode register (IM2) is detected, IRQ2 is set. For example, if KR4-KR7 are selected, IRQ2 is set if the falling edge is input to any one of KR4-KR7, because KR4-KR7 inputs are ANDed in the $\mu$ PD753XX. Fig. 6.3-4 shows the format of the edge detection mode registers used to select detected edge (IM0 to IM2). IM0 to IM2 are set individually by using a 4-bit memory operation instruction. When RESET signal is generated, all the register bits are cleared; INT0, INT1, and INT2 detection edges are specified to rising edges. Fig. 6.3-1 INTO and INT1 Configuration Fig. 6.3-2 INT2 and KR0-KR7 Configuration When a high level is input successively, the noise eliminator outputs a high level; when a low level is input successively, it outputs a low level. Fig. 6.3-3 Noise Eliminator Input/Output Timing Caution: If the edge detection mode register is changed, the interrupt request flag may be set. Disable interrupts beforehand, and change the mode register. Clear the interrupt request flag by using the CLR1 instruction before enabling interrupts. If f<sub>x</sub>/64 is selected for the sampling clock in an IMO change, clear the interrupt request flag within 16 machine cycles after the mode register is changed. Fig. 6.3-4 Edge Detection Mode Register Format (3) Interrupt master enable flag (IME) Interrupt master enable flag enables or disables acknowledgement of all interrupts. IME is set to 1 or to 0 by using the El and DI instructions. When the RESET signal is generated, IME is cleared, disabling acknowledgement of all interrupts. #### Address Fig. 6.3-5 IME Format ## (4) Interrupt status flag The interrupt status flag (IST0) indicates the current status of processing being performed by CPU; it is contained in the PSW. The interrupt control circuit controls multi-interrupts (as listed in Table 6.3-2) according to the contents of interrupt status flag. Since IST0 can be changed by using a 4-bit or a one-bit manipulation instruction, multi-interrupt can also be implemented by changing the status of processing being performed. Multi-interrupt can always be implemented regardless of the MBE setting when IST0 is handled bitwise. Be sure to execute the DI instruction to disable interrupts before handling IST0 and the EI instruction to enable interrupts after handling IST0. When an interrupt is acknowledged, IST0 is saved in stack memory together with other PSW bits, then it is automatically set to 1. When the RETI instruction is executed, the former IST0 value (0) is restored. When the RESET signal is generated, the flag is cleared. Table 6.3-2 IST0 and Interrupt Service State | IST0 | Status of processing | CPU processing contents | Interrupt requests that can be acknowledged | After interrupt is acknowledged | |------|----------------------|----------------------------------|---------------------------------------------|---------------------------------| | | | | | IST0 | | 0 | Status 0 | During normal program processing | All interrupts can be acknowledged. | 1 | | 1 | Status 1 | During interrupt service | None of the interrupts can be acknowledged. | ı <del>-</del> , | #### 6.4 Interrupt Sequence When an interrupt occurs, it is processed as shown in Fig. 6.4-1. Remarks: 1. IST0: Interrupt status flag (PSW bit 2). (See Table 6.3-2) 2. Store the interrupt service program start addresses and MBE setup values at the interrupt start in the vector table. Fig. 6.4-1 Interrupt Service Flow #### 6.5 Multi-interrupt Service Control The $\mu PD753XX$ enables multi-interrupts as described below. As understood from Table 6.3-2, multi-interrupt is enabled if the interrupts status flag is changed by a program. That is, multi-interrupt is enabled if IST0 is changed to 0 by the interrupt service program setting status 0. To change IST0, execute the DI instruction beforehand to disable interrupts. Fig. 6.5-1 Multi-Interrupt by Changing Interrupt Status Flag ### 6.6 Vector Address Share Interrupt Service Since INTBT and INT4 interrupt sources share the vector table addresses, interrupt source selection is made as described below: # (1) To use one interrupt only Set the interrupt enable flag to 1 for the required one of the two interrupt sources sharing the vector table addresses, and clear the interrupt enable flag of the other interrupt source. In this case, an interrupt request is generated from the interrupt source corresponding to the interrupt enable flag that is set to 1 (IEXXX = 1). When the interrupt request is acknowledged, the interrupt request flag is cleared. #### (2) To use both interrupts Set both the interrupt enable flags of the two interrupt sources to 1. In this case, an interrupt request is made by ORing the interrupt request flags of the two interrupt sources. Even if an interrupt request is acknowledged when either or both of the interrupt request flags are set to 1, the interrupt request flags are not reset. Therefore, the interrupt service routine must decide which interrupt source the interrupt is generated from. This is accomplished by executing the SKTCLR instruction to check the interrupt request flags. If both the interrupt request flags are set to 1 when the request flags are tested and cleared by execution of the SKTCLR instruction, the interrupt request is left even if one request flag is cleared. If IST0 is cleared, dual interrupt service is entered according to the left interrupt request. Remarks: When only one interrupt is enabled, the source of an interrupt is known. Thus, the interrupt request flag is cleared by hardware when interrupt is acknowledged. When both interrupts are enabled, the source of an interrupt is not defined; thus, interrupt request flag cannot be cleared by hardware. Software is used to check the interrupt request flags and determine the interrupt source. Interrupt request flag is cleared by software. Example: When INT4 takes precedence over INTBT #### 6.7 Machine Cycles to Interrupt Service Start The number of the µPD753XX machine cycles required to start execution of the interrupt routine after an interrupt request flag is set is as shown below: (1) When IRQn is set during execution of an operating instruction at data memory address FBxH (interrupt hardware)) FBxH address operating instruction As shown above, interrupt routine processing is started a maximum of six machine cycles after the data memory (address FBxH) operating instruction is terminated. (Within a maximum of six machine cycles after the last operating instruction is terminated if the FBxH address operating instructions are successive.) (2) When IRQn is set during execution of instruction other than in (1). In this case, a maximum of six machine cycles are required. ## 6.8 Effective Use of Interrupts Use the interrupt function as described below: (1) Set MBE = 0 in the interrupt service routine. If the data memory area used in the interrupt service routine is preferentially allocated to addresses 0-7FH and MBE = 0 is set in the interrupt vector table, a program can be prepared without considering memory banks. If memory bank 1 must be used for by the program, save the memory bank select register by using the PUSH BS instruction and select memory bank 1. (2) Use software interrupt for debugging. When an interrupt request flag is set by an instruction, operating is performed in the same manner as if an interrupt occurred. Debugging when more than one interrupt occurred at the same time can be done effeciently by using an instruction to set an interrupt request flag. #### 6.9 Interrupt Application To use the interrupt function, first set the following in the main program: - (1) Set the interrupt enable flags to be used (EI IEXXX instructions). - (2) To use INT0 and INT1, select the active edge. (set IM0 and IM1.) - (3) Set the interrupt master enable flag (El instruction). - Since MBE is set by using the vector table in an interrupt service program, registers need not be saved or restored, and the interrupt program can be started immediately. To return from the interrupt service program, use the RETI instruction. ## (1) Interrupt enable and disable - ① All interrupts are disabled by the RESET signal. - ② The interrupt enable flags are set by the El IEXXX instructions. At this stage, all interrupts remain disabled. - ③ The interrupt master enable flag is set by the EI instruction. At this stage, INTO and INTTO are enabled. - (4) The interrupt enable flag is cleared by the DI IEXXX instruction and INTO is disabled. - (5) All interrupts are disabled by the DI instruction. (2) Usage example of INTBT, INT0 (falling edge active), and INTT0. Multi-interrupt is not done. - ① All interrupts are disabled by the RESET signal and status 0 is set. - ② Falling edge active is selected for INTO. - ③ Interrupts are enabled by the EI and EI IEXXX instructions. - 4 On the INTO falling edge, the INTO interrupt service program is started. The status is changed to status 1 and all interrupts are disabled. - S A return is made from the interrupt service program by the RETI instruction. The status is restored to status 0 and interrupts are enabled. (3) Pending interrupt execution - interrupt input during interrupt disable - - ① If INT0 is set during interrupt disable, the request flag is held. - ② When interrupts are enabled by the El instruction, the INTO service program is started. - 3 Simular to 1 above. - When INTCSI is held enabled, the INTCSI service program is started. # (4) Pending interrupt execution - ① If INTO and INTTO are occured at the same time during execution of a single instruction, INTO, which is higher in priority than INTTO, is executed first; INTTO is held. - When a return is made from the INT0 service program by the RETI instruction, the held INTT0 service program is started. (5) Enable of two double interrupts - INTT0 and INT0 enable double interrupts; INTCSI and INT4 are single interrupts - - ① When interruptINTCSI occurs, which does not enable double interrupts, the INTCSI service program is started. Status 1 is set. - ② The status is changed to status 0 by clearing IST0. INTCSI and INT4 do not enable double interrupt and are disabled. - When INTTO enables double interrupts, the double interrupt is executed, the status is changed to status 1, and all interrupts are disabled. - At the termination of INTTO service, the status is restored to status 0. - (b) Disabled INTCSI and INT4 are enabled and a return is made by the RETI instruction. #### 7. STANDBY FUNCTION To make the most of low current consumption, which is one feature of the CMOS process, the µPD753XX can stop CPU operation in the standby mode making current consumption by the CPU very small. The µPD753XX standby mode includes the STOP mode and HALT mode. The STOP mode stops the main system clock oscillator. In this mode, CPU current consumption consists almost entirely of leakage current. Data memory can also be held with low supply voltage (up to $V_{\rm DD}$ = 2 V). This features is useful for maintaining the data memory contents with very low current consumption. Since the $\mu$ PD753XX STOP mode can be released by using an interrupt request, intermittent operation can also be performed. However, if processing must be started immediately when an interrupt request is made, note that the wait time required to ensure oscillator stability is taken when the STOP mode is released. The HALT mode continues system clock oscillator operation but stops the CPU clock $(\Phi)$ supply; thus, CPU operation is stopped. Although the HALT mode is inferior to the STOP mode for reduction of current consumption, it is useful to restart processing immediately according to an interrupt request or for performing intermittent operations such as watch operation. In either mode, all the register, flag, and data memory contents immediately before the standby mode is entered are held. The input/output port output latch state and output buffer state are also held. The input/output port state is handled beforehand so that the current consumption of the entire system is minimized. #### Cautions on Use of Standby Mode: - 1. The STOP mode can be used only when µPD753XX operation uses the main system clock. (Subsystem clock oscillation cannot be stopped.) The HALT mode can be used when the µPD753XX uses either main system or subsystem clock. - If the STOP mode is set when the LCD controller/driver and watch clock operate on the main system clock f<sub>x</sub>, they stop operation. To continue operation, change to the subsystem clock f<sub>xT</sub> before setting STOP mode. - 3. Although efficient operation with low current consumption and low voltage can be performed by using the clock change function between the CPU and system clocks in combination with the standby mode, time (described in 5.2.3) is required from selection of a new clock by setting the control register until operation is started by the newly selected clock. Thus, to use the clock change function and the standby mode in combination, set the standby mode within the time required for the clock change. ## 7.1 Standby Mode Setting and Operating State Table 7.1-1 Operating State in Standby Mode | | | STOP mode | HALT mode | | | | |-----------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|--| | Setting instr | uction | STOP instruction | HALT instruction | | | | | System cloc | k when standby mode is set. | Can be set only during main system clock. | Can be set during either main system or subsystem clock. | | | | | | Clock oscillator | Only the main system clock oscillator is stopped. | Only CPU clock $\Phi$ is stopped (oscillation is continued). | | | | | | Basic interval timer | Operation stop | Operation (IRQBT is set at reference time intervals.) | | | | | | Serial interface | Can operate only when external SCK input is selected for serial clock. | Can operate. | | | | | Operating state | Timer/event counter | Can operate only when TI0 pin input is selected for count clock. | Can operate. | | | | | | Watch timer | Can operate when $f_{XT}$ is selected for count clock. | Can operate. | | | | | | LCD controller | Can operate only when $f_{XT}$ is selected for LCDCL. | Can operate. | | | | | | External interrupts | INT1, INT2, and INT4 can operate. Only | INT0 cannot operate. | | | | | | CPU | Operation stop | | | | | | Release signal | | Interrupt request signal enabled with interrupt enable flag from operating hardware (except for INT0), or RESET input. | | | | | The STOP mode is set by using the STOP instruction to set PCC bit 3; the HALT mode is set by the using HALT instruction to set PCC bit 2. To change the CPU clock by using the low-order two bits of PCC, a time lag may occur from PCC rewrite to CPU clock change. Thus, to change the clock before the standby mode is entered or after the standby mode is released, set the standby mode within the number of machine cycles required to change the CPU clock after PCC is rewritten. While operation stops during the standby mode, data is held in all registers and data memory such as general-purpose registers, flags, mode register, and output latches. - Caution: 1. When the STOP mode is set, X1 input is short-circuited to V<sub>SS</sub> (GND potential) internally to suppress crystal oscillator leakage. Therefore, so not use the STOP mode in a system using external clock as a main system slock. - 2. Since an interrupt request signal is used to release the standby mode, if both interrupt request and enable flags are set for an interrupt source, the standby mode is immediately released. Thus, for the STOP mode, the HALT mode is entered immediately after execution of the STOP instruction, a wait is followed according to for the setup time of the BTM register, then a return is made to the opertion mode. #### 7.2 Realising Standby Mode The standby mode (STOP or HALT) is released when an interrupt request signal (except INT0) enabled with an interrupt enable flag occurs or RESET is input. Fig. 6.2-1 shows the standby mode release operation. Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (d) Releasing HALT node by interrupt generation Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (cont'd) If the STOP mode is released when an interrupt occurs, the wait time is determined by BTM setting. (See Table 7.2-1.) The time until oscillation becomes stable varies according to the type of oscillator being used and the supply voltage when the STOP mode is released. Therefore, select the wait time according to the conditions of use and set BTM before setting the STOP mode. Table 7.2-1 Wait Time Selection by Using BTM | втмз | ВТМ2 | BTM1 | втмо | Wait time* ( ) indicates f <sub>xx</sub> = 4.19 MHz | | |------------------|------|------|------------------------------------------------------------|------------------------------------------------------------|--| | _ | 0 | 0 | 0 | APPROX. 2 <sup>20</sup> /f <sub>xx</sub> (Approx. 250 ms) | | | _ | 0 | 1 | 1 | APPROX. 2 <sup>17</sup> /f <sub>xx</sub> (Approx. 31.3 ms) | | | - | 1 | 0 | 1 | APPROX. 2 <sup>15</sup> /f <sub>xx</sub> (Approx. 7.82 ms) | | | - 1 1 1 | | 1 | APPROX. 2 <sup>13</sup> /f <sub>xx</sub> (Approx. 1.95 ms) | | | | Other than above | | | | Use Prohibited | | Note: The wait time when STOP mode is released does not include the time until the clock begins to <u>oscillate</u> after STOP mode is released ((a) in the figure below) regardless of whether STOP mode was released by RESET input or interrupt generation. ### 7.3 Operation After Standby Mode is Released - (1) If the standby mode is released when RESET is input, normal reset operation is performed. - (2) If the standby mode is released when an interrupt request occurs, the contents of the interrupt master enable flag (IME) determine whether or not a vectored interrupt is made when the CPU restarts instruction execution. - (a) When IME = 0 - After the standby mode released, execution restarts at the NOP instruction next to the standby mode setting instruction. The interrupt request flags are held. - (b) When IME = 1 - After the standby mode is released, two instructions following the standby mode setting instruction are executed before a vectored interrupt is executed. - However, if the standby mode is released by using INTW or INT2 (testable input), no vectored interrupt will occur; processing as in (a) above is performed. ### 7.4 Application of Standby Mode To use the standby mode, follow the procedure described below: - Detect a standby mode setting source such as interrupt input or port input for power off (it is effective to use INT4 for power off detection). - 2) Handle input/output ports so that current consumption is minimized. - 3) Specify interrupt to release the standby mode. (It is effective to use INT4. Clear the interrupt enables flags so as not to release the standby mode.) - 4) Specify operation after the standby mode is released (set IME depending on whether or not interrupt service is made). - 5) Specify the CPU clock after the standby mode is released. (To change the clock, wait for the required number of machine cycles before setting the standby mode.) - 6) Select the wait time in release of standby mode. - 7) Set the standby mode by using the STOP or HALT instruction. Use of the standby mode and system clock change function in combination enables the $\mu$ PD753XX to operate at low current consumption and low voltage. #### (1) Example of STOP mode application Use the STOP mode under the following conditions - Set the STOP mode when the INT4 falling edge is input and release it when the rising edge is input. (Do not use INTBT.) - Place all input/output ports in high impedance. - Use interrupts INT0 and INTT0 in the example program; however, do not use them to release the STOP mode. - Enable interrupts after the STOP mode is released. - After the STOP mode is released, start operation on the minimum speed CPU clock, and in 250 ms, change it to high-speed clock. - Set the wait time for STOP mode release to about 31.3 ms. - After the STOP mode is released, wait for 31.3 ms for the power supply to become stable. Check the P00/INT4 pin twice and remove chattering. ## (2) HALT mode application Perform intermittent operation under the following conditions - Change to the subsystem clock on the falling edge of INT4. - Stop oscillation of the main system clock and set the HALT mode. - Perform intermittent operation at 0.5sec. intervals during the standby mode. - Again change to the main system clock on the rising edge of INT4. - Do not use INTBT. ``` ΕI IE4 El IEW ΕI ; Enable interrupt (Main routine) SKT PORT0.0 : Power OK? HALT Power down mode NOP Power OK? SKTCLR IRQW ; Is 0.5sec. flag set? ; NO BR MAIN WATCH CALL ; Watch subroutine MAIN: (INT4 service routine) INT4: SKT PORT0.0 ; Power OK?, MBE=0, RBE=0 BR PDOWN CLR1 SCC.3 ; Start oscillation of main system clock MOV A, #8 MOV BTM, A WAIT1: SKT IRQBT ; Wait for 250 ms BR WAIT1 SKT PORT0.0 ; Check chattering BR PDOWN CLR<sub>1</sub> SCC.0 ; Change to main system clock MOV XA. #04H ; Main system clock ``` | | MOV<br>BETI | WM, XA | | |--------|-------------|--------------------|---------------------------------------------| | PDOWN: | MOV | XA, #05H | ; Subsystem clock | | | MOV<br>MOV | WM, XA<br>XA, #00H | | | | MOV | LCDM, XA | ; LCD display off | | | MOV | LCDC, A | | | | SET1 | SCC.0 | ; Change to subsystem clock | | | MOV | A, #6 | tina ta | | WAIT2: | INCS | Α | ; Wait for 32 machine cycles | | | BR | WAIT2 | | | | SET1 | SCC.3 | ; Stop oscillation of main system clock | | | RETI | | | Note: When the system clock is changed after power on from main system clock to subsystem clock, change the system clock after the subsystem clock is stabilized. ## 8. RESET FUNCTION The μPD753XX is reset when RESET is input. The hardware devices are initialized as listed inTable 8.1-1. Fig. 8.1-1 shows the reset operation timing. Fig. 8.1-1 Reset Operation by RESET is input Table 8.1-1 State After Each Hardware Device is Reset | | Hard | Hardware RESET input during standby mode RESET input during opera | | | | | |---------------------|------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--|--| | Program co | ounter (PC) | μPD75304 | The low-order four bits of program memory address 0000H are loaded into PC11-PC8. The contents of address 0001H are loaded into PC7-PC0. | | | | | | | μPD75306,<br>μPD75308 | The low-order five bits of program mer PC12-PC8. The contents of address 0 | | | | | | | μPD75312,<br>μPD75316 | The low-order six bits of program men PC13-PC8. The contents of address 0 | | | | | PSW | Carry flag | (CY) | Held | Undefined | | | | | Skip flag ( | SK0-SK2) | 0 | 0 | | | | | Interrupt s | tatus flag (IST0) | 0 | 0 | | | | | Bank enable flag | | Bit 7 of program memory address 000 | 0H is loaded into MBE. | | | | Stack point | ck pointer (SP) | | Undefined | Undefined | | | | Data memo | nemory (RAM) | | Held (Note) | Undefined | | | | General-pu | rpose regis | ters (X, A, H, L, D, E, B, C) | Held | Undefined | | | | Bank selec | tion register | (MBS) | 0 | 0 | | | | Basic interv | al timer | Counter (BT) | Undefined | Undefined | | | | | | Mode register (BTM) | 0 | 0 | | | | Timer even | t counter | Counter (T0) | 0 | 0 | | | | | | Modulo register<br>(TMOD0) | FFH | FFH | | | | Mode register (TM0) | | Mode register (TM0) | 0 | 0 | | | | | TOE0, TOUT F/F | | 0, 0 | 0, 0 | | | | Watch time | r | Mode register (WM) | 0 | 0 | | | | Serial inter | face | Shift register (SIO) | Held | Undefined | | | Table 8.1-1 State After Each Hardware Device is Reset (Cont'd) | | Hardware | RESET input during standby mode | RESET input during operation | | | | |--------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------|--|--|--| | Serial | Operation mode register (CSIM) | 0 | 0 | | | | | interface | SBI control register (SBIC) | 0 | 0 | | | | | | Slave address register (SVA) | Held | Undefined | | | | | Clock<br>generator | Processor clock control register (PCC) | 0 | 0 | | | | | and clock<br>output<br>circuit | System clock control register (SCC) | 0 | 0 | | | | | Circuit | Clock output mode register (CLOM) | 0 | 0 | | | | | LCD | Display mode register (LCDM) | 0 | 0 | | | | | controller | Display control register (LCDC) | 0 | 0 | | | | | Interrupt | Interrupt request flags (IRQXXX) | Reset to 0 | Reset to 0 | | | | | function | Interrupt enable flags (IEXXX) | 0 | 0 | | | | | | Interrupt master enable flag (IME) | 0 | 0 | | | | | | INT0, INT1, and INT2 mode registers (IM0, IM1, and IM2) | 0, 0, 0 | 0, 0, 0 | | | | | Digital | Output buffers | Off | Off | | | | | ports | Output latches | Cleared | Cleared | | | | | | Input/output mode registers (PMGA, B) | 0 | 0 | | | | | | Pull-up resistor specification register (POGA) | 0 | 0 | | | | | Bit sequent | tial buffer (BSB0-BSB3) | Held | Undefined | | | | | Pins<br>condition | P00-P03, P10-P13, P20-P23,<br>P30-P33, P60-P63, P70-P73, | Input | Input | | | | | | P40-P43, P50-P53, | | High level<br>High impedance | | | | | الله على الله | S0-S23, COM0-COM3 | Note 2 | | | | | | | BIAS | At incorporated split resistor: Low level At not incorporated split resistor: High impedance | | | | | Note: The data of data memory address 0F8H-0FDH is undefined by RESET input. Note: The data of data memory address pron-urbh is undefined by NESE1 hipput. Note2: Each display output is selected as V<sub>LCX</sub> input source. S0-31: V<sub>LC1</sub> COM0-COM2: V<sub>LC2</sub> COM3: V<sub>LC2</sub> However, each display output level is changed by each display output and V<sub>LCX</sub> external circuit. # 9. ELECTRICAL CHARACTERISTICS # Absolute Maximum Ratings (Ta = 25 °C) | Item | Symbol | Conditions | | | Ratings | Unit | |-----------------------|---------------------|--------------------|------------------------------------|------------------|------------------------------|------| | Supply voltage | V <sub>DD</sub> | | | | -0.3 to +7.0 | ٧ | | Input voltage | V <sub>11</sub> | Other than ports | 4 and 5 | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | V <sub>12</sub> (1) | Ports 4 and 5 | With internal | pull-up resistor | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | | | Open drain | | -0.3 to +11 | ٧ | | Output voltage | v <sub>o</sub> | | | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | High level | I <sub>OH</sub> | Single pin | Single pin Total, all outputs | | | mA | | output current | | Total, all outputs | | | | | | Low level | l <sub>oL</sub> | Single pin | | Peak value | 30 | | | output current | Note | | | Effective value | 15 | | | | | Ports 0, 2, 3 and | 5 total | Peak value | 100 | | | | | | | Effective value | 60 | mA | | | | Ports 4, 6, and 7 | Ports 4, 6, and 7 total Peak value | | 100 | | | | | Effective value | | 60 | | | | Operation Temperature | T <sub>opt</sub> | | | | -40 to +85 | °C | | Storage Temperature | T <sub>stg</sub> | | | | -65 to +150 | °C | Note: Use the following formula to calculate the effective value. (Effective value) = (Peak value) x $\sqrt{\text{duty}}$ # Characteristics of Main System Clock Oscillator (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------------|--------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|------|------| | Ceramic | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 1.0 | | 5.0 | MHz | | resonator C1 | C1 + C2<br>V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization time | After V <sub>DD</sub> reaches the minimum value in the oscillator voltage range | | | 4 | ms | | | X1 X2 C1 C2 C2 V <sub>DD</sub> | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 1.0 | 4.19 | 5.0 | MHz | | Crystal<br>resonator | | Note 2<br>Oscillation | V <sub>DD</sub> =4.5 to 6.0V | | | 10 | ms | | | | stabilization time | | | | 30 | ms | | External clock | X1 X2<br>μPD74HCU04 | Note 1<br>X1 input frequency<br>(f <sub>X</sub> ) | | 1.0 | | 5.0 | MHz | | | | X1 input high/low level width (t <sub>XH</sub> , t <sub>XL</sub> ) | | 100 | | 500 | ns | Note 1: The oscillation frequency and X1 input frequency are indicated only to express the characteristics of the oscillator. Refer to the AC characteristics for instruction execution time. Note 2: The oscillation stabilization time is the time required for the oscillator to stabiliate after V<sub>DD</sub> is applied or after the STOP mode is released. # Subsystem Clock Oscillator Characteristics (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------|-----------------------|-----------------------------------------------------------------------|-----------------------|------|--------|------|------| | Crystal | XT1 XT2 | Oscillation frequency (f <sub>XT</sub> ) | | 32 | 32.768 | 35 | MHz | | rogeneter | 22 p = 33 pF | 0: | $V_{DD} = 4.5 - 6.0V$ | | 1 | 2 | s | | _ | V <sub>DD</sub> | Stabilization time | The Artist Control | | | 10 | s | | External clock | XT1 XT2 | XT1 input frequency (f <sub>XT</sub> ) | | 32 | | 100 | kHz | | External clock | | XT1 input high/low level width (t <sub>XTH</sub> , t <sub>XTL</sub> ) | | 5 | | 15 | μs | # **Recommended Resonator** Main system clock: ceramic resonator | Maunfacture | Product name | External capacitors (pF) | | Oscillator operating voltage range (V) | | Remarks | |-------------|---------------------------------------------|--------------------------|--------------|----------------------------------------|------|-----------------| | | | C1 | C2 | MIN. | MAX. | | | | CSA 2.00MG093 | 15 | 15 | 2.5 | 3.5 | Note | | | CSB 1000D20 | 220 | 220 | | - | | | Murata | CSA 2.00MG093<br>CSA 4.19MGU<br>CSA 4.91MGU | 30 | 30 | 2.7 | 6.0 | | | · | CST 2.00MG093<br>CST 4.19MGU<br>CST 4.91MGU | not required | not required | | | Internal C type | | | KBR-1000H | 100 | 100 | | | | | Kyocera | KBR-2.0MS | 47 | 47 | | | | | | KBR-4.0MS<br>KBR-4.19MS<br>KBR-4.91MS | 33 | 33 | 2.7 | 6.0 | | Note: When CSA 2.000G093 is used, VDD is 2.5 to 3.5V. Main system clock: crystal resonator | Maunfacture | Freg. Holder | External capacitors (pF) | | Oscillator operating voltage range (V) | | Remarks | |-------------|------------------------------------------------------|--------------------------|----|----------------------------------------|------|---------| | | | C1 | C2 | MIN. | MAX. | | | Kinseki | 1.00<br>2.00 HC-18/U<br>4.19 HC-49/U<br>4.91 HC-43/U | 22 | 22 | 2.7 | 6.0 | | # Subsystem clock: 32.768 KHz crystal resonator | Maunfacture | Product name | External capacitors (pF) | | Oscillator operating voltage range (V) | | Remarks | | |-------------|--------------|--------------------------|---------|----------------------------------------|------|---------|--| | | | C1 (pF) | C2 (pF) | R (kΩ) | MIN. | MAX. | | | Kinseki | P-3 | 22 | 22 | 330 | 2.7 | 6.0 | | # Capacitance (Ta = 25 $^{\circ}$ C, $V_{DD}$ = 0V) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Units | |--------------------------|-----------------|---------------------------|------|------|------|-------| | Input capacitance | C <sub>IN</sub> | f =1 MHz | | | 15 | рF | | Output capacitance | Соит | For other than pins to be | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | measured, 0V. | | | 15 | pF | # DC Characteristics (Ta = –40 to +85 $^{\circ}\text{C},~\text{V}_{\text{DD}}$ = 2.7 to 6.0V) | li o m | Cumbal | 00 | Conditions | NAINI | TVD | I MAY | 11-14 | |----------------------------------|-------------------|------------------------------------------|--------------------------------------------------------------------------|----------------------|----------|--------------------|-------| | Item | Symbol | - | Conditions | MIN. | TYP. | MAX. | Unit | | High level input voltage | V <sub>IH1</sub> | Ports 2 and 3 | | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | | V <sub>IH2</sub> | Ports 0, 1, 6, 7, an | d RESET pin | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | | | V <sub>IH3</sub> | Ports 4 to 5 | With built-in pullup resistor | 0.7V <sub>DD</sub> | <u>.</u> | V <sub>DD</sub> | . , V | | | | | Open drain | 0.7V <sub>DD</sub> | | 10 | V | | | V <sub>IH4</sub> | X1, X2, XT1 | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | V | | Low level input | V <sub>IL1</sub> | Ports 2, 3, 4, 5 | | 0 | | 0.3V <sub>DD</sub> | ٧ | | voltage | V <sub>IL2</sub> | Ports 0, 1, 6, 7, an | d RESET pin | 0 | | 0.2V <sub>DD</sub> | V | | | V <sub>IL3</sub> | X1, X2, XT1 | | 0 | | 0.4 | V | | High level output voltage | V <sub>OH1</sub> | Ports 0, 2, 3, 6, 7,<br>BIAS | $V_{DD} = 4.5 \text{ to } 6.0 \text{V}$<br>$I_{OH} = -1 \text{ mA}$ | V <sub>DD</sub> -1.0 | | | ٧ | | | | | I <sub>OH</sub> = -100μA | V <sub>DD</sub> -0.5 | | | ٧ | | | V <sub>OH2</sub> | BP0-7 (with two I <sub>OH</sub> outputs) | $V_{DD} = 4.5 \text{ to } 6.0 \text{V}$<br>$I_{OH} = -100 \mu\text{A}$ | V <sub>DD</sub> -2.0 | | | ٧ | | | | | I <sub>OH</sub> = -30μA | V <sub>DD</sub> -1.0 | | | ٧ | | Low level output voltage | V <sub>OL1</sub> | Port 0, 2 – 7 | Ports 3, 4, 5<br>V <sub>DD</sub> = 4.5 to 6.0V<br>I <sub>OL</sub> = 15mA | | 0.4 | 2.0 | ٧ | | | | 1. | V <sub>DD</sub> = 4.5 to 6.0V<br>I <sub>OL</sub> = 1.6mA | | | 0.4 | ٧ | | | | | I <sub>OL</sub> = 400μA | | | 0.5 | ٧ | | | | SB0, 1 | Open drain Pull-up register<br>≥ 1kΩ | | | 0.2V <sub>DD</sub> | V | | | V <sub>OL2</sub> | BP0-7 (with two I <sub>OL</sub> outputs) | $V_{DD} = 4.5-6.0V$ $I_{OL} = 100\mu A$ | 2004<br>1000 1000 | | 1.0 | ٧ | | | | | I <sub>OL</sub> = 50μA | | | 1.0 | ٧ | | High level input | I <sub>LIH1</sub> | V <sub>IN</sub> = V <sub>DD</sub> | Other than indicated below | | | 3 | μΑ | | leakage current | I <sub>LIH2</sub> | | X1, X2, XT1 | | | 20 | μΑ | | | I <sub>LIH3</sub> | V <sub>IN</sub> = 10V | Ports 4, 5 (with open drain) | 7.0 | | 20 | μА | | Low level input | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V | Other than indicated below | | | -3 | μА | | leakage current | I <sub>LIL2</sub> | | X1, X2, XT1 | | | -20 | μΑ | | High level output | I <sub>LOH1</sub> | V <sub>OUT</sub> = V <sub>DD</sub> | Other than indicated below | | | 3 | μА | | leakage current | I <sub>LOH2</sub> | V <sub>OUT</sub> = 10V | Ports 4 and 5 (with open drain) | | | 20 | μА | | Low level output leakage current | I <sub>LOL</sub> | V <sub>OUT</sub> = 0V | | | | -3 | μΑ | | Internal pull-up resistor | R <sub>L1</sub> | Ports 0, 1, 2, 3, 6, 7 (Except P00) | V <sub>DD</sub> = 5.0V ± 10% | 15 | 40 | 80 | kΩ | | 10313101 | | V <sub>IN</sub> = 0V | V <sub>DD</sub> = 3.0V ± 10% | 30 | | 200 | kΩ | # **DC Characteristics** (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Item | Symbol | | Condition | าร | | MIN. | TYP. | MAX. | Unit | |----------------------------------------------|------------------|-----------------------------------------|--------------------------------------------------------------|---------------------|-----------|------|-------|-----------------|------| | Internal pull-up resistor | R <sub>L2</sub> | Ports 4 and 5 | V <sub>DD</sub> = 5.0V ± 10% | | 15 | 40 | 70 | kΩ | | | resistor | | V <sub>OUT</sub> =V <sub>DD</sub> -2.0V | V <sub>DD</sub> = 3. | 0V ± 10% | 6 | 10 | | 60 | kΩ | | LCD drive voltage | V <sub>LCD</sub> | | | | | 2.5 | | V <sub>DD</sub> | ٧ | | LCD split resistor | R <sub>LCD</sub> | | | | | 60 | 100 | 150 | kΩ | | LCD output<br>voltage deviation<br>(common) | V <sub>ODC</sub> | I <sub>O</sub> = ±5μΑ | $V_{LCD0} = V_{LCD}$ $V_{LCD1} = V_{LCD} \times {}^{2}/_{3}$ | | 0 | | ±0.2V | ٧ | | | LCD output<br>voltage deviation<br>(segment) | V <sub>ODS</sub> | $I_O = \pm 1\mu A$ | $V_{LCD2} = V_{LCD} x^{1}/_{3}$ (Note 4) | | 0 | | ±0.2V | V | | | Supply current (Note 1) | | (Note 5)<br>4.19 MHz crystal | ` ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' | | | 2.5 | 8 | mA | | | (Note 1) | I <sub>DD1</sub> | oscillation<br>C1=C2=22pF | V <sub>DD</sub> = 3\ | / ± 10% ( | (Note 3) | | 0.35 | 1.2 | mA | | | | 01=02=22pr | HALT<br>Mode | V <sub>DD</sub> = 5 | 5V ± 10% | | 500 | 1500 | μА | | | DD2 | | wode | V <sub>DD</sub> = 3 | 3V ± 10% | | 150 | 450 | μА | | | I <sub>DD3</sub> | 32kHz crystal | V <sub>DD</sub> = 3\ | / ± 10% | | | 30 | 90 | μА | | | I <sub>DD4</sub> | resonator<br>(Note 6) | HALT<br>Mode | V <sub>DD</sub> = 3 | 3V ± 10% | | 5 | 15 | μА | | | | XT1 = 0 | V <sub>DD</sub> = 5\ | / ± 10% | | | 0.5 | 20 | μА | | | DD5 | STOP mode | V <sub>DD</sub> = 3\ | / ± 10% | | | 0.1 | 10 | μА | | | | | | | Ta = 25°C | | 0.1 | 5 | μА | Note 1: The currents of the built-in pull-up resistor and the LCD step-down resistor are not included. Note 2: When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. Note 3: When operated in the low-speed mode with the PCC set to 0000. Note 4: $2.7 \text{V} \le \text{V}_{\text{LCD}} \le \text{V}_{\text{DD}}$ Note 5: Includes the power consumption for the sub system oscillation. Note 6: When the system clock control registor (SCC) is set to 1001, sub system clock oscillation is stopped and operated by subsystem clock. # AC Characteristics (Ta = -40 to +85 C, $V_{DD}$ = 2.7 to 6.0V) | Item | Symbol | Condi | tion | MIN. | TYP. | MAX | Unit | |-------------------------------------------------|------------------|-------------------------------------|-----------------------------|------|------|-----|------| | (Note 1) Cycle time | | Operation with main | V <sub>DD</sub> = 4.5 -6.0V | 0.95 | | 64 | μs | | (minimum instruction execution time) | | system clock | | 3.8 | | 64 | μs | | | t <sub>cy</sub> | Operation with sub-<br>system clock | | 114 | 122 | 125 | μs | | | | V <sub>DD</sub> = 4.5 - 6.0V | | 0 | | 1 | MHz | | TI0 input frequency | f <sub>TI</sub> | | | 0 | | 275 | kHz | | TI0 input high/low level t <sub>TIH</sub> width | | $V_{DD} = 4.5 - 6.0V$ | | 0.48 | | | μs | | widin | t <sub>TIL</sub> | | | 1.8 | | | μs | # AC Characteristics (Ta = -40 to 85 C, $V_{DD}$ = 2.7 to 6.0V) (cont'd) | Item | Symbol | Condition | MIN. | TYP. | MAX | Unit | |--------------------------|-------------------|------------|--------|------|-----|------| | Interrupt input high/low | t <sub>INTH</sub> | INTO | Note 2 | | | μs | | level width | | INT1, 2, 4 | 10 | | | μs | | | t <sub>INTL</sub> | KR0-7 | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | 10 | | | μs | Note 1: The cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure below shows the V<sub>DD</sub> vs cycle time $(t_{CY})$ when operated with the main system clock. Note 2: $2t_{CY}$ or $128/f_{\chi}$ , depending on the setting of the interrupt mode register (IM0). **Serial Transfer Operation** 2-line/3line serial I/O mode (SCK ... Internal clock output) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------------------------|------------------------|------|------|------| | | | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | SCK cycle time | t <sub>KCY1</sub> | | 3800 | | | ns | | SCK high/law lavel | t <sub>KL1</sub> | V <sub>DD</sub> = 4.5 -6.0V | t <sub>KCY1</sub> -50 | | | ns | | SCK high/low level width | t <sub>KH1</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SI set-up time<br>(against SCK ) | t <sub>SIK1</sub> | | 150 | | | ns | | SI hold time<br>(against SCK ) | t <sub>KSI1</sub> | | 400 | | | ns | | SCK<br>SO output delay<br>time | | V <sub>DD</sub> = 4.5 -6.0V | | | 250 | ns | | | <sup>T</sup> KSO1 | | | | 1000 | ns | 2-line/3line serial I/O mode (SCK ... External clock input) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------------------------|------|------|------|------| | | | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | SCK cycle time | t <sub>KCY2</sub> | | 3200 | | | ns | | SCK high/low level width | t <sub>KL2</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | | ns | | | t <sub>KH2</sub> | | 1600 | | | ns | | SI set-up time<br>(against SCK ) | t <sub>SIK2</sub> | | 100 | | | ns | | SI hold time (against SCK ) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK | | V <sub>DD</sub> = 4.5 -6.0V | | | 300 | ns | | | <sup>t</sup> KSO2 | | | | 1000 | ns | Note: The output delay time (for rising edge) of the serial line must be shorter than 600 ns. For example, if SB0 and SBI are pulled up with 5K ohms, the total capacitance of the serial bus line must be no greater than 120 pF. SBI mode (SCK ... Internal clock output (master)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |---------------------------------------|-------------------|-----------------------------|------------------------|------|------|------| | SCK cycle time | | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | 30K cycle line | tксүз | | 3800 | | | ns | | SCK high/low level | t <sub>KL3</sub> | V <sub>DD</sub> = 4.5 -6.0V | t <sub>KCY1</sub> -50 | | | ns | | width | t <sub>KH3</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SB0,1 set-up time<br>(against SCK † ) | t <sub>sık3</sub> | | 150 | | | ns | | SB0,1 hold time (against SCK ) | t <sub>KSI3</sub> | | t <sub>KCY1</sub> | | | ns | | SCK<br>SB0,1 output delay | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 250 | ns | | time | t <sub>KSO3</sub> | | 0 | | 1000 | ns | | SCK - SB0,1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 → SCK | t <sub>sвк</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | v. | ns | SBI mode (SCK ... External clock input (slave)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------------------------|---------------------|------|------|------| | SCK cycle time | avalo timo | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | 30K cycle line | t <sub>KCY4</sub> | | 3200 | | | ns | | SCK high/low level | t <sub>KL4</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | | ns | | width | t <sub>KH4</sub> | | 1600 | | | ns | | SB0,1 set-up time (against SCK ) | t <sub>SIK4</sub> | | 100 | | | ns | | SB0,1 hold time (against SCK ) | t <sub>KSI4</sub> | | t <sub>KCY1</sub> 2 | | | ns | | SCK | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 300 | ns | | SB0,1 output delay time | t <sub>KSO4</sub> | | 0 | | 1000 | ns | | SCK → SB0,1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1↓ → SCK↓ | t <sub>sвк</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1 and XT1 inputs) Clock Timing **TIO Timing** Serial Transfer Timing 3-line serial I/O mode # **Serial Transfer Timing** Interrupt input timing RESET input timing # Data Memory STOP Mode Low Voltage Data Retention Characteristic ( $Ta = -40 \text{ to } +85 \text{ }^{\circ}\text{C}$ ) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------------------------------|-------------------|------------------------------|------|---------------------------------|------|------| | Data retention voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention current (Note1) | IDDDR | V <sub>DDR</sub> = 2.0V | | 0.1 | 10 | μА | | Release signal set time | t <sub>SREL</sub> | | 0 | | | με | | 0 - 11-11-1-11-11-11-11-11-11-11-11-11-11 | | Release by RESET input | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | scillation stabilization time (Note 2) t <sub>WAIT</sub> | | Release by interrupt request | | Note 3 | | ms | Note 1: Current in the internal pull-up resistors is not included. Note 2: The oscillation stabilization time is the time required before beginning CPU operation in order to prevent unstable CPU operation when oscillation is initiated. Note 3: Depends on the setting of the basic interval timer mode register (BTM) (refer to the table below). | ВТМ3 | BTM2 | BTM1 | ВТМ0 | WAIT time ( ) indicates f <sub>X</sub> =4.19MHz | |------|------|------|------|---------------------------------------------------------| | _ | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>X</sub> (Approximately 250 ms) | | _ | 0 | 1 | 1 | 2 <sup>17</sup> /f <sub>X</sub> (Approximately 31.3 ms) | | _ | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>X</sub> (Approximately 7.82 ms) | | _ | 1 | . 1 | 1 | 2 <sup>13</sup> /f <sub>X</sub> (Approximately 1.95 ms) | Data Retention Timing (when STOP mode is released by RESET input) Data Retention Timing (Standby release signal: STOP mode release by interrupt signal) #### **Characteristic Curves** (Ta = 25 °C) Power supply current I<sub>DD</sub> (µA) I<sub>DD</sub> vs V<sub>DD</sub> (Ceramic oscillation) (Ta = 25 °C) <sup>\*</sup>The Current values are increased by approximately 10% compared to when operating with a crystal resonator. Power supply current I<sub>DD</sub> (µA) Power supply current IDD (µA) \* Of pins BP0 to BP3 or BP4 to BP7, number of pins outputting the same level. 0.1<sup>±0.1</sup> $0.1^{\pm0.1}$ ES 80-pin Ceramic QFP (Reference Diagram) (Units in mm) ### Caution: - 1. If the metal cup is connected to pin 33, it becomes V<sub>SS</sub> level. - 2. The bottom's leads are diagonally configured. - 3. As the lead edges are not performed process control in metal machining, lead length is not specified. ### 10. $\mu$ PD75P308K (UVPROM) / $\mu$ PD75P308/P316GF (OTPROM) 4-BIT MICROCOMPUTERS. #### 10.1 Overview The $\mu$ PD75P308/16 is a single-chip 4-bit microcomputer which is supplied as a plastic otprom (one time programmable) or ceramic uvprom with window. The single-chip includes, timer/event counters, serial interface and vector interrupt. These functions are incorporated along with CPU, PROM, RAM and I/O ports. The $\mu$ PD75P308/16 is pin-compatible with the $\mu$ PD75308/16 and equivalent to the device in function. Due to the simplicity of the programming requirements, the $\mu$ PD75P308/16 is suitable for evaluation of the $\mu$ PD75308/16. The $\mu PD75P308$ will be use for emulation of $\mu PD75304/306/308$ and the $\mu PD75P316$ for $\mu PD75312/316$ . The µPD75P308/16 should not be used for final EMI and Latch up evaluation. #### Note: | Memory type | μPD75P308 | μPD75P316 | | | |-------------|--------------|---------------|--|--| | ROM | 8064 x 8 bit | 16256 x 8 bit | | | | RAM | 512 x 4 bit | 512 x 4 bit | | | #### 10.2 Features · 42 types of instructions. Numerous bit manipulation instructions. 8-bit transfer instructions. 1-byte relative branch instructions. GETI instruction that realizes arbitrary 2-byte instructions in 1-byte units. - Programmable instruction cycle: 0.95μs, 1.91μs, 15.3μs / 4.19MHz (main system oscillator), 122μs / 32kHz (sub system oscillator) at 5V - Size of data memory (RAM): 512 x 4 bit (memory bank configuration) - · Memory-mapped I/O (memory bank configuration) - Memory for bit manipulation (bit-sequential buffer: 16 bits) - General-purpose register: 4 bits x 8 (one register bank) - · Accumulators: Bit accumulator (0 4-bit accumulator (A) 8-bit accumulator (XA) LCD controller/driver LCD drive segment outputs: 32 LCD drive common outputs: 4 LCD drive mode — static - 1/2 bias - 1/2 duty, 1/3 duty - 1/3 bias - 1/3 duty, 1/4 duty • External expansion port for LCD controller/driver, serial connection. • 32 I/O lines CMOS In/Out Pins Middle-high voltage N-ch open drain In/Out ports: 2 LED direct drive port: 3 - · Vector interrupt function capable of multiple interrupts, 3 external vector interrupts - 1 external test input - 3 internal vector interrupts - 1 internal test interrupt - · Basic interval timer - · One 8-bit timer/event counter - Watch timer (0.5 sec test flag) - · 8 bit serial interface: - Conventional 75, 75X compatible mode - Serial bus interface (SBI) mode - · Internal clock oscillator with crystal/ceramic resonator - Subsystem and main system oscillators, run CPU on 32kHz subsystem. - Standby operation (STOP/HALT) - CMOS low power consumption - μPD75P308/16GF: 80 PIN plastic flat pack one time programmable OTPROM - μPD75P308K: 80 PIN ceramic LCC package UVPROM 10.3 Block Diagram 11-3-185 S0-31 : Segment output 0-31 P00-03 : Port 0 P10-13 : Port 1 Common output 0-3 COM0-3: LCD power supply 0-2 P20-23 : Port 2 V<sub>LC0-2</sub> BIAS LCD power supply bias control P30-33 : Port 3 LCDCL : LCD clock P40-43 : Port 4 SYNC: LCD synchronization P50-53 : Port 5 TIO: Timer input 0 P60-63 : Port 6 P70-73 : Port 7 PTO0: Programmable timer output 0 Buzzer clock BUZ: BP0-7 : Bit port Programmable clock KR0-7 : Key return PCL: SCK : Serial clock INTO, 1, 4: External vectored interrupt 0, 1, 4 External test input 2 SI: Serial input INT2: Main system clock oscillation 1, 2 SO: Serial output X1, 2: Subsystem clock oscillation 1, 2 SB0, I: Serial bus 0, I XT1, 2 : RESET: Reset input V<sub>PP</sub>: Program Power Supply MD0-MD3 : Mode 0-3 ### 10.5 Pin Functions 10.5.1 Port Pins | Pin | Input/Output | Serve<br>Pin f | | Functions | | | At Reset | I/O Circuit<br>Type (Note 1) | |---------------------|---------------|----------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|---|---------------------|------------------------------| | P00 | Input | INT | 4 | 4-bit input port (PORT0). Incorporation of pull-up resistors in 3-bit units for P01 to P03 specifiable by software. | | | Input | B | | P01 | Input/Output | SC | ĸ. | | | | | F-A | | P02 | Input/Output | SO/S | В0 | | | | | F-B | | P03 | Input/Output | SI/S | ВІ | | | | | (M) -C | | P10 | Input | INT | 0 | | Noise elimination | Х | Input | B-c | | P11 | | INT | 1 | | function available | | | | | P12 | | INT | 2 | 4-bit input port (POF<br>Incorporation of pull- | RT1).<br>up resistors in 4-bit units | | | | | P13 | | TIC | ) | specifiable by software. | | | | | | P20 | Input/Output | PTC | 00 | 4-bit input/output po | | х | Input | E-B | | P21 | | _ | | Incorporation of pull-<br>specifiable by softwa | up resistors in 4-bit units are. | | | | | P22 | | PC | L | | | | | | | P23 | | BU | Z | | | | | | | P30 (Note 2) | Input /Output | LCDCL | MD0 | Programmable 4-bit | | х | Input | E-B | | P31 (Note 2) | | SYNC | MD1 | Input/output setting is possible in bit units. In corporation of pull up resistors in 4 bit units specifiable by software. | | | | | | P32 (Note 2) | | MD | 2 | | | | | | | P33 (Note 2) | | MD | 3 | | | | | | | P40-P43<br>(Note 2) | Input/Output | _ | - | N-channel open drain 4-bit input/output port (PORT4). Data input/output pin (lower 4-bits) for use during program memory (PROM) write/ verify operations. | | 0 | High Im-<br>pedance | M-B | | P50-P53<br>(Note 2) | Input/Output | _ | - | (PORT5). | in 4-bit input/output port n (upper 4-bits) for use nory (PROM) write/ | | High Impedance | M-B | | P60 | Input/Output | KR | 0 | Programmable 4-bit | input/output port | 0 | Input | F-A | | P61 | | KR | 1 | (PORT 6). This port can be specified for input/output in bit units. Incorporates software-specifiable pull-up resistors in 4-bit units. | | | - | | | P62 | ]. | KR | 2 | | | | | | | P63 | | KR | 3 | | | | - | | | P70 | Input/Output | KR | 4 | 4-bit input/output po | | 1 | Input | F-A | | P71 | | KR | 5 | Incorporation of pu<br>units specifiable by | II-up resistors in 4-bit software. | | | | | P72 | | KR | 6 | | | | | | | P73 | | KR | .7 | | | | | | ### 10.5.1 Port Pins (cont'd) | Pin | Input/Output | Serves as<br>Pin for | Functions | 8-Bit<br>I/O | At Reset | I/O Circuit<br>Type (Note 1) | |-----|--------------|----------------------|-----------------------------------------|--------------|----------|------------------------------| | BP0 | Output | S24 | 1-bit output port (BIT PORT). | Х | (Note 3) | G-A | | BP1 | | S25 | Also serves as the segment output pins. | 1 | | | | BP2 | | S26 | | | 1 12 - | | | BP3 | | S27 | | | | | | BP4 | Output | S28 | ) · · · · · · · · · · · · · · · · · · · | | | | | BP5 | | S29 | | | | | | BP6 | | S30 | | | | | | BP7 | | S31 | | | | | Note 1: Circles indicate Schmitt trigger inputs. Note 2: LED direct drive is possible. Note 3: BP0-7 select V<sub>LC1</sub> as the input source. The output level changed by the external circuit of BP0-7 and V<sub>LC1</sub>. ### 10.5.2 Non-Port Pins | Pin | Input/Output | Serves as<br>Pin for | Functions | At Reset | I/O Circuit<br>Type (Note 1) | |------------------------------------|--------------|----------------------|-------------------------------------------------------------------------------------|----------|------------------------------| | TIO | Input | P13 | External event pulse input pin for timer/event counter. | | B-c | | PTO0 | Input/Output | P20 | Timer/event counter output pin. | Input | E-B | | PCL | Input/Output | P22 | Clock output pin. | Input | E-B | | BUZ | Input/Output | P23 | Fixed-frequency output pin (for buzzer or system clock trimming). | Input | E-B | | SCK | Input/Output | P01 | Serial clock input/output pin. | Input | Ē-A | | SO/SB0 | Input/Output | P02 | Serial data output pin. Serial bus input/output pin. | Input | ⊕-B | | SI/SBI | Input/Output | P03 | Serial data input pin. Serial bus input/output pin. | Input | <b>∭</b> -C | | INT4 | Input | P00 | Edge detector vector interrupt input pin (either rising or falling edge detection). | | B | | INT0 | Input | P10 | Edge detector interrupt input pin (detected edge selectable). | | B-C | | INT1 | | P11 | (detected edge selectable). | | | | INT2 | Input | P12 | Edge detection testable input pin (rising edge detection). | | B-C | | KR0-KR3 | Input/Output | P60-P63 | Testable input/output pin (for falling edge detection). | Input | Ē-A | | KR4-KR7 | Input/Output | P70-P73 | Testable input/output pin (for falling edge detection). | Input | Ē-A | | S0-S23 | Output | | Segment signal output pin. | (Note 3) | G -A | | S24-S31 | Output | BP0-7 | Segment signal output pin. | (Note 3) | G -A | | COM0<br>-COM3 | Output | | Common signal output pin. | (Note 3) | G -B | | V <sub>LC0</sub> -V <sub>LC2</sub> | | | LCD drive power supply. | | | ### 10.5.2 Non-Port Pins | Pin | Input/Output | Serves as<br>Pin for | Functions | At Reset | I/O Circuit<br>Type (Note 1) | |-------------------|--------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------| | BIAS | | | Output pin for divided resistor cut externally installed. | Hi-Z | | | LCDCL<br>(Note 2) | Input/Output | P30 | Clock output pin for activating the externally extended driver. | Input | E-B | | SYNC<br>(Note 2) | Input/Output | P31 | Clock output pin for synchronizing the externally extended driver. | Input | E-B | | X1, X2 | Input | | Pin for connection of crystal/ceramics for main system clock generation. External clocks are input to X1, and their negative phase components are input to X2. | | | | XT1 | Input | | Pin for connection of crystals for sub-system clock generation. External clocks are input to XT1, and | | | | XT2 | | | XT2 is disconnected. XT1 can also be used as a 1-bit input (test) pin. | | | | RESET | Input | | System reset input pin (low level active). | | В | | MD0-MD3 | Input/Output | P30-P33 | Mode selector pin for program memory (EPROM) write/verify operations. | Input | E-B | | V <sub>PP</sub> | | | Program voltage application pin for program memory (EPROM) write/verify operations. V <sub>pp</sub> is normally connected to V <sub>DD</sub> . Connect to +12.5V for EPROM write/verify operations. | | | | V <sub>DD</sub> | | | Positive power supply pin. | | | | V <sub>SS</sub> | | | GND potential pin. | | | Note 1: Circles indicate Schmitt trigger inputs. Note 2: Pins for future use in system extention. Pins LCDCL and SYNC currently serve only as P30 and P31, respectively. Note 3: For each display output, the following V<sub>LCX</sub> are selected as input sources: S0-S31: V<sub>LC1</sub>, COM0-COM2: V<sub>LC2</sub>, COM3: V<sub>LC0</sub> However, the display output level varies depending on the display output and V<sub>LCX</sub> external circuit. Internal LCD split resistors are not included! ### Pin I/O configurations Following figures show the internal circuit configurations at the I/O ports. (1) Type A (part of Type E-B) This is a CMOS standard input buffer. (2) Type B This is a Schmitt trigger input with hysteresis characteristics. (3) Type B-C This is a Schmitt trigger input with hysteresis characteristics. (4) Type D (Part of Type E-B, F-A) This is a push-pull output that can be set to high impedance (with both P-ch and N-ch off). (5) Type E-B ### (6) Type F-A ### (7) Type F-B ### (8) Type G-A ### (9) Type G-B ### (10) Type M-B ### (11) Type M-C ### P.U.R.: Pull-Up resistor ### 10.6 DIFFERENCES BETWEEN $\mu$ PD75P308/P316 AND $\mu$ PD753XX Because the μPD75P308/P316 is a product that incorporates an on-chip, writeable PROM in place of the masked ROM in the μPD753XX program memory, the μPD75P308/P316 and the μPD753XX have similar hardware and perform similar CPU They differ simply in their type of program memory and mask options. Tables 10.6-1 shows these differences. Refer to the $\mu PD753XX$ Users' Manual for details of hardware and CPU functions. Table 10.6-1 Differences between $\mu\text{PD75P308}$ and $\mu\text{PD75308}$ | Item | | μPD75P308K | μPD75P308GF | μPD75308GF | | |-----------------------------------|-----------|----------------------------------------------------|-------------|----------------------------------------------------------|--| | Program memory | | • EPROM<br>• 0000-1F7FH<br>• 8064 x 8 bits | | Masked ROM 0000–1F7FH 8064 x 8 bits | | | Pull-up resistor | Ports 4,5 | No | Mask option | | | | Divided resistor drive power supp | | No | Mask option | | | | Pin configuration | 1 | ${ m V_{pp}}$ pin and PROM program pins available. | | V <sub>PP</sub> pin and PROM program pins not available. | | | Power voltage range | | 5 V ± 5 % | | 2.7 to 6.0 V | | | Package | | 80-pin ceramic LCC package (with window). | 80-pin pi | plastic QFP. | | ### Table 10.6-2 Differences between µPD75P316 and µPD75316 | Item | | μPD75P316GF | μPD75316GF | | |----------------------------------|-----------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--| | Program memory | | <ul> <li>PROM (one-time programable version)</li> <li>0000–1F7FH</li> <li>16256 x 8 bits</li> </ul> | <ul><li>Masked ROM</li><li>0000–1F7FH</li><li>16256 x 8 bits</li></ul> | | | Pull-up resistor | Ports 4,5 | None | Mask option | | | Divided resistor drive power sup | | None | Mask option | | | Pin configuration | 1 | V <sub>PP</sub> pin and PROM program pins available. | V <sub>PP</sub> pin and PROM program pins not available. | | | Power voltage range | | 5 V ± 5 % 2.7 to 6.0 V | | | | Package | | 80-pin plastic QFP. | | | ### 10.7 PROM WRITE AND VERIFICATION Program memory contained in the $\mu$ PD75P308, $\mu$ PD75P316 is PROM. The memory capacity is as follows: μPD75P308: 8064 words x 8 bits μPD75P316: 16256 words x 8 bits The pins as listed in Table 10.7-1 are used to write and verify the PROM. No address is input; address is updated by inputting clock from the X1 pin instead. ### Table 10.7-1 Pin function | Pin name | Function | |-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | X1, X2 | Address update clock during when PROM is write/verification is input to the X1 pin. Its inverted signal is input to the X2 pin. | | MD0-MD3 | Operation mode selection pins during PROM write/verification. | | P40-P43 (low-order four bits)<br>P50-P53 (high-order four bits) | 8-bit data input/output pins during PROM write/verified. | | V <sub>DD</sub> | Supply voltage apply pin. During the normal operation, 5 V $\pm$ 5 % is applied; during PROM write/verification, +6 V is applied. | | V <sub>PP</sub> | Voltage apply pin during PROM write/ verification. (Normally, V <sub>DD</sub> potential) | Caution 1: Put a shading cover film on the µPD75P308K having a window, except when the PROM contents are erased. Caution 2: µPD75P308GF, µPD75P316GF of the one-time version does not have a window, and the PROM contents cannot be erased with ultraviolet rays. ### 10.7.1 Operating Mode during PROM is Write/Verification When +6 V and +12.5 V are applied to the V<sub>DD</sub> and V<sub>PP</sub> pins, respectively, of the µPD75P308, µPD75P316 the PROM write/verify mode is entered. The operation mode is selected according to the input signals to the MD0-MD3 pins as listed in Table 10.7-2. Pins not used in EPROM function should be pulled to $V_{\rm SS}$ . Table 10.7-2 Operating Mode | | Ор | erating mod | de specifica | Operating mode | | | |-----------------|-----------------|-------------------------|--------------|----------------|-----|------------------------------| | V <sub>DD</sub> | V <sub>PP</sub> | MD0 | MD1 | MD2 | MD3 | Operating mode | | | | Н | L | Н | L | Clear program memory address | | +12.5 V | +6 V | L | Н | Н | Н | Write mode | | +12.5 V | +0 V | 6 V L L H H Verify mode | | Verify mode | | | | | | Н | Х | Н | Н | Program inhibit mode | Remarks: X: L or H ### 10.7.2 PROM Write Procedure PROM can be written at the high speed according to the following Procedure: - (1) Pull unused pins low to $V_{SS}$ with resistors. Set the X1 pin low. (2) Supply 5 V to the $V_{DD}$ and $V_{PP}$ pins. - (3) Wait for 10 us. - (4) Selected the clear program memory address mode. - (5) Supply +6 V and +12.5 V to the $V_{\rm DD}$ and $V_{\rm PP}$ pins. - (6) Select the program inhibit mode. - Write data in the 1-ms write mode. (7) - (8) Select the program inhibit mode. - (9) Select the verify mode. If the data is written normally, proceed to (10). If it is not written normally, repeat (7) to (9). - (10)Supply X (number of (7)–(9) repetitions) x 1 ms program pulses (additional write). - (11)Select the program inhibit mode. - (12) Input four pulses to the X1 pin to update the program memory address by one. - Repeat (7)-(12) until the end address is reached. (13) - (14) Select the clear program memory address mode. - (15) Change the $V_{\rm DD}$ , $V_{\rm PP}$ pin voltage to 5 V. - (16) Turn off the power. Steps (2) to (12) are illustrated below: ### 10.7.3 PROM Read Procdure The PROM contents can be read according to the following procedure: - (1) Pull unused pins low to V<sub>SS</sub> with resistors. - Set the X1 pin low. - Supply 5 V to the $V_{\rm DD}$ and $V_{\rm PP}$ pins. (2) - (3) Wait for 10 μs. - (4) Select the clear program memory address mode. - (5) Supply + 6 V and + 12.5 V to the V<sub>DD</sub> and V<sub>PP</sub> pins. - (6) Select the program inhibit mode. - (7) Select the verify mode. Input four clock pulses to the X1 pin. The data are output from the memory addresses, one address at a time, in a cycle of hour clock pulses which are input to the X1 pin. - (8) Select the program inhibit mode. - (9) Select the clear program memory address mode. - (10) Change the V<sub>DD</sub>, V<sub>PP</sub> voltage to 5 V. (11) Turn off the power. Steps (2) to (12) are illustrated below: ### 10.7.4 Erasion Method The programmed data contents of the $\mu$ PD75P308K can be erased by applying light whose wave length is shorter than about 400 nm. The programmed data contents may also be erased when the $\mu$ PD75P308K is subjected to direct sunlight or fluorescent light for hours. To project the data contents, mask the $\mu$ PD75P308K with a shading cover film to prevent ultraviolet rays from being entered through the upper window. Shading cover film whose quality has been tested is attached to UV PROM product for shipment by NEC. For normal erasion, apply 254-nm ultraviolet rays to the $\mu$ PD75P308K. All the radiation amount required to erase the $\mu$ PD75P308K contents completely is 15 Ws/cm² (ultraviolet lenght x erasion time) at the minmum. This corresponds to about 15–20 minutes when a 12000 Ws/cm² ultraviolet ray lamp is used for erasion. However, note that the erasion time may be prolonged due to the ultraviolet lamp life, dirty package window, etc. Place the $\mu$ PD75P308K and ultraviolet ray lamp within 2.5–cm distance. ### 10.8 Electrical charactaristics ### Absolute Maximum Rating (Ta=25°C) | Prameter | Symbol | Con | dition | Rating | Unit | |-----------------------|-----------------------------|------------------|-----------------|------------------------------|------| | 0 | V <sub>DD</sub> | | | | V | | Supply voltage | V <sub>PP</sub> | | | -0.3 to +13.5 | V | | | V <sub>11</sub> | Other than ports | 4 and 5 | -0.3 to V <sub>DD</sub> +0.3 | V | | Input voltage | (Note 1)<br>V <sub>12</sub> | Ports 4 and 5 | Opendrain | -0.3 to +11 | V | | Output voltage | V <sub>o</sub> | | | -0.3 to V <sub>DD</sub> +0.3 | V | | High-level | | 1 pins | | -15 | mA | | output current | 'он | All other pins | | -30 | mA | | | | 1 pins | Peak value | 30 | mA | | | | | Effective value | 15 | - mA | | Low-level | (Note 2) | Total of ports | Peak value | 100 | mA | | output current | l <sub>OL</sub> | 0, 2, 3 and 5 | Effective value | 60 | mA | | | | Total of ports | Peak value | 100 | mA | | | | 4, 6 and 7 | Effective value | 60 | mA | | Operating temperature | T <sub>opt</sub> | | | -10 to +70 | °C | | Storage temperature | T <sub>stg</sub> | | | -65 to +150 | °C | Note 1: When applying more than 10 volts to ports 4 or 5, the pull-up resistor must be 50K ohms min. 2: Effective value is obtained as follows: (Effective) value = (Peak value) x √duty cycle ### Main system clock Oscillator Characteristics $(Ta = -10 \text{ to } +70^{\circ}\text{C}, V_{DD} = 5\text{V} + /-5\%)$ | Resonator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-----------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|------|------| | Note 3<br>Ceramic<br>resonator | X1 X2 | Note 1<br>Oscillation<br>frequency (f <sub>XX</sub> ) | | 1.0 | | 5.0 | MHz | | | C1 C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization<br>time | When V <sub>DD</sub> reaches<br>the minimum<br>oscillator operating<br>voltage. | | | 4 | ms | | Crystal resonator | X1 X2 | Note 1<br>Oscillation<br>frequency (f <sub>XX</sub> ) | | 1.0 | 4.19 | 5.0 | MHz | | | C1 C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization<br>time | | | | 10 | ms | | External clock | X1 X2 | Note 1<br>X1 input<br>frequency (f <sub>X</sub> ) | | 1.0 | | 5.0 | MHz | | : | μPD74HCU04 | X1 input high/<br>low level<br>width (t <sub>XH</sub> / t <sub>XL</sub> ) | | 100 | | 500 | ns | - Note 1: The oscillation frequency and X1 input frequency values indicated in this table express only the characteristics of the oscillator. Therefore, refer to the AC characteristics for the instruction execution time. - Oscillation stabilization time is defined as the time needed for the oscillator to stabilize after V<sub>DD</sub> is applied or after the STOP mode is released. - 3: The following ceramic and crystal oscillators are recommended for the μPD75P308/316. #### **Recommended Ceramic Resonators** | Manufacture | Duradicat | External cap | pacitance (pF) | Operating voltage range (V) | | | |-------------|-------------|----------------------------------|----------------------------------|-----------------------------|------|--| | Manufacture | Product | C1 | C2 | MIN. | MAX. | | | MURATA | CSA 2.00MG | 30 | 30 | 4.75 | 5.25 | | | | CSA 4.19MG | 30 | 30 | 4.75 | 5.25 | | | | CSA 4.19MGU | 30 | 30 | 4.75 | 5.25 | | | | CST 4.19MG | 30pF<br>(internally<br>provided) | 30pF<br>(internally<br>provided) | 4.75 | 5.25 | | ### **Subsystem Clock Oscillator Characteristics** (Ta =-10 to +70°C, V<sub>DD</sub> =5V+/-5%) | Resonator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |-------------------|-----------------------------|-----------------------------------------------------------------------------|---------------------------|------|--------|------|------| | Crystal resonator | [XT1 XT2]<br> | Oscillation<br>frequency<br>(f <sub>XT</sub> ) | | 32 | 32.768 | 35 | kHz | | | 22 pF 33 pF V <sub>DD</sub> | Oscillation<br>stabilization<br>time | V <sub>DD</sub> =4.5~6.0V | | 1.0 | 2 | s | | External clock | XT1 XT2 Open | XT1 input<br>frequency<br>(f <sub>XT</sub> ) | | 32 | | 100 | kHz | | | <b>Å</b> | XT1 input high/<br>low level width<br>(t <sub>XTH</sub> /t <sub>XTL</sub> ) | | 5 | | 15 | μs | ### Capacitance (Ta =25°C, $V_{DD}$ =0V) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------|------------------|------------------------------------------------------------|------|------|------|------| | Input capacitance | C <sub>IN</sub> | f=1 MHz | : | | 15 | pF | | Output capacitance | C <sub>out</sub> | Voltage should not be applied to any pin except those used | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | for measurements. | | | 15 | pF | ## DC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V±5%) | Parameter | Symbol | Cond | dition | MIN. | TYP. | MAX. | Unit | |----------------------------|-------------------|----------------------------------|--------------------------------------|----------------------|-----------------|--------------------|------------| | | V <sub>IH1</sub> | Port 2, 3 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | | High-level | V <sub>IH2</sub> | Port 0, 1, 6, 7, RESET | | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | V <sub>IH3</sub> | Port 4, 5 Open-drain | | 0.7V <sub>DD</sub> | | 10 | V | | | V <sub>IH4</sub> | X1, X2, XT1 | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | V V | | | V <sub>IL1</sub> | Port 2, 3, 4, 5 | | 0 | | 0.3V <sub>DD</sub> | , <b>V</b> | | Low-level<br>input voltage | V <sub>IL1</sub> | Port 0, 1, 6, 7, RESET | - | 0 | | 0.2V <sub>DD</sub> | ٧ | | par romage | V <sub>IL3</sub> | X1, X2, XT1 | 0 | | 0.4 | V | | | d limb laval | V <sub>OH1</sub> | Port 0, 2, 3, 6, 7, BIAS | I <sub>OH</sub> =-1mA | V <sub>DD</sub> -1.0 | | | V | | High-level output voltage | | BPO-7 | I <sub>OH</sub> =-100μA<br>Note 4 | V <sub>DD</sub> -2.0 | | | V | | | V <sub>OL1</sub> | Port 0, 2, 3, 4, 5, 6, 7 | Port 3, 4, 5 I <sub>OL</sub> =15mA | | 0.4 | 2.0 | V | | | | | I <sub>OL</sub> =1.6mA | | | 0.4 | ٧ | | Low-level output voltage | V <sub>OL2</sub> | SB0, 1 open-drain | Pull-up resistor<br>(R) =1k ohm min. | | | 0.2V <sub>DD</sub> | ٧ | | | V <sub>OL3</sub> | BP0-7 | I <sub>OL</sub> =100μA<br>Note 4 | | | 1.0 | V | | High-level | I <sub>LIH1</sub> | V <sub>IN</sub> =V <sub>DD</sub> | Other than X1, X2, and XT1 pins | | | 3 | μА | | input leakage<br>current | I <sub>LIH2</sub> | טט אוו | X1, X2, XT1 | | | 20 | μА | | | I <sub>LIH3</sub> | V <sub>IN</sub> =10V | Port 4, 5 | | | 20 | μА | ### DC Characteristics (Ta =-10 to +70°C, V<sub>DD</sub> =5V±5%) | Parameter | Symbol | Cond | lition | MIN. | TYP. | MAX. | Unit | |----------------------------------------|-------------------|--------------------------------------------|---------------------------------|------|------|-----------------|------| | Low-level input leakage | l <sub>LIL1</sub> | V <sub>IN</sub> =0V | Other than X1, X2, and XT1 pins | | | -3 | μА | | current | I <sub>LIL2</sub> | "" | X1, X2, XT1 | | | -20 | μА | | High-level<br>output leakage | I <sub>LOH1</sub> | V <sub>OUT</sub> =V <sub>DD</sub> | Other than ports<br>4 and 5 | | | 3 | μА | | current | I <sub>LOH2</sub> | V <sub>OUT</sub> =10V | Port 4,5 | | | 20 | μА | | Low-level<br>output leakage<br>current | I <sub>LOL</sub> | V <sub>OUT</sub> =0V | | | | -3 | μА | | Internal<br>pull-up<br>resistor | R <sub>LI</sub> | Port 0, 1, 2, 3, 6, 7 (exce | 15 | 40 | 80 | kΩ | | | LCD drive voltage | V <sub>LCD</sub> | | | 2.5 | | V <sub>DD</sub> | ٧ | | Common output impedance | R <sub>COM</sub> | Note 3 | | | 3 | 6 | kΩ | | Segment<br>output<br>impedance | R <sub>s</sub> | Note 3 | | | 15 | 20 | kΩ | | | I <sub>DD1</sub> | Note 5 | Note 2 | | 5 | 15 | mA | | Note 1 | I <sub>DD2</sub> | 4.19 MHz crystal<br>oscillation C1=C2=22pF | HALT mode | | 500 | 1500 | μΑ | | Supply | | Note 6<br>32kHz crystal | | | 350 | 1000 | | | | DD3 | oscillation | HALT mode | | 35 | 100 | μΑ | | | I <sub>DD4</sub> | XT1 =0V STOP mode | | | 0.5 | 20 | μΑ | 1. The current drained through the internal pull-up resistors is not included. - 2. When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. - 3. 2.5V ≤ V<sub>LCD</sub> ≤ V<sub>DD</sub> 4. When any two pins of BP0 to BP3 and any two pins of BP4 to BP7 are used simultaneously for output. - 5. Including the subsystem clock power consumption. - 6. When system clock control register (SCC) is set to 1001; main system clock's oscillation halted once sub-system clock in operation. # AC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5 $V\pm5\%$ ) Operation other than serial transfer operation | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------------------|-------------------------------------|---------------------------------|--------|------|------|------| | Note 1 | | Operated with main system clock | 0.95 | | 64 | μs | | Cycle time (minimum instruction execution time) | CY | Operated with sub-system clock | 114 | 122 | 125 | μs | | TI0 input frequency | f <sub>TI</sub> | | 0 | | 1 | MHz | | TI0 input high/low level width | t <sub>TIH</sub> , t <sub>TIL</sub> | | 0.48 | | | μs | | Interrupt input | | INT0 | Note 2 | | | μs | | high/low level width | 'INTH' 'INTL | KR0-7, INT1 2, 4 | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | 10 | | | μs | - Note 1. Cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure to the right shows the V<sub>DD</sub> supply voltage vs. cycle time (t<sub>CV</sub>) characteristic when operated with the main system clock. - Either 2t<sub>CY</sub> or 64/f<sub>XX</sub> can be selected by setting the interrupt mode register (IMO). ### **Serial Transfer Operation** ### 2-line/3-line serial I / 0 mode (SCK....Internal clock output) | E-mic/o-mie schai i/ o mode (o | OIX | iai ciock output) | | | | | |--------------------------------|--------------------------------------|-------------------|-----------------------------|------|------|------| | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | | SCK cycle time | t <sub>KCY1</sub> | Output | 1600 | | | ns | | SCK high / low level width | t <sub>KL1</sub><br>t <sub>KH1</sub> | Output | t <sub>KCL1</sub> /2<br>-50 | | | ns | | SI set-up time (against SCK) | t <sub>SIK1</sub> | | 150 | | | ns | | SI hold time (against SCK ∤ ) | t <sub>KSI1</sub> | | 400 | | | ns | | SCK - S0 output delay time | t <sub>KSO1</sub> | | | | 250 | ns | ### 2-line / 3-line serial I/0 mode (SCK....External clock input) : | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------|--------------------------------------|-----------|------|------|------|------| | SCK cycle time | t <sub>KCY2</sub> | Input | 800 | | | ns | | SCK high / low level width | t <sub>KL2</sub><br>t <sub>KH1</sub> | Input | 400 | | | ns | | SI set-up time (against SCK†) | t <sub>SIK2</sub> | | 100 | | | ns | | SI hold time (against SCK 1) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK - S0 output delay time | t <sub>KSO2</sub> | | | | 300 | ns | ### SBI Mode (SCK....Internal clock output Master)): | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------|--------------------------------------|-----------|----------------------------|------|------|------| | SCK cycle time | t <sub>KCY3</sub> | | 1600 | | | ns | | SCK high / low level width | t <sub>KL3</sub><br>t <sub>KH3</sub> | | t <sub>KCY</sub> /2<br>-50 | | | ns | | SB0, SB1 set-up time (against SCK†) | t <sub>SIK3</sub> | | 150 | | | ns | | SB0, SB1 hold time (against SCK†) | t <sub>KSI3</sub> | | t <sub>KCY</sub> /2 | | | ns | | SCK↓ → SB0, SB1 output delay time | t <sub>KSO3</sub> | | 0 | | 250 | ns | | SCK SB0, SB1 ↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 ↓ → SCK ↓ | t <sub>SBK</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 high level width | t <sub>SBH</sub> | | t <sub>KCY</sub> | | | ns | ### SBI Mode (SCK.... External clock input (Slave)): | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |---------------------------------------|--------------------------------------|-----------|---------------------|------|------|------| | SCK cycle time | t <sub>KCY4</sub> | | 800 | | | ns | | SCK high / low level width | t <sub>KL4</sub><br>t <sub>KH4</sub> | | 400 | | | ns | | SB0, SB1 set-up time (against SCK ) | t <sub>SIK4</sub> | · | 100 | | | ns | | SB0, SB1 hold time (against SCK ) | t <sub>KSI4</sub> | | t <sub>KCY</sub> /2 | | | ns | | SCK ↓ → SB0, SB1 output delay time | t <sub>KSO4</sub> | | 0 | | 300 | ns | | SCK - SB0, SB1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 - SCK | t <sub>SBK</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 high level width | t <sub>SBH</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1, XT1 input) Clock Timing **TIO Timing** Serial Transfer Timing 3-line serial I/O mode ### Command signal transfer: Interrupt input timing RESET input timing ### Data Memory STOP Mode Low Supply Voltage Data Retention Characteristic ( $Ta = -10 \text{ to } +70 \text{ }^{\circ}\text{C}$ ) | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------------------|-------------------|------------------------------|------|---------------------------------|------|------| | Data retention supply voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention supply current (Note1) | I <sub>DDDR</sub> | V <sub>DDDR</sub> = 2.0V | | 0.1 | 10 | μΑ | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | Contillation at all libraries with the | | Release by RESET input | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | Oscillation stabilization wait time (Note 2) | TWAIT | Release by interrupt request | | Note 3 | | ms | Note 1: The current drained through the internal pull-up resistor is not included Note 2: The oscillation stabilization wait time is used to prevent unstable CPU operation at the beginning of oscillator operation, during which CPU operation is disabled. Note 3: This value depends on the setting of the basic interval timer mode register (BTM). (Refer to the table below.) | ВТМ3 | BTM2 | BTM1 | втмо | WAIT time Parantheses ( ) indicates f <sub>X</sub> =4.19MHz | |------|------|------|------|-------------------------------------------------------------| | _ | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>X</sub> (Approximately 250 ms) | | | 0 | 1 | 1 | 2 <sup>17</sup> /f <sub>X</sub> (Approximately 31.3 ms) | | _ | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>X</sub> (Approximately 7.82 ms) | | | 1 | , 1 | 1 | 2 <sup>13</sup> /f <sub>X</sub> (Approximately 1.95 ms) | Data Retention Timing (Releasing STOP mode by RESET) Data Retention Timing (Standby release signal: Releasing STOP mode by interrupt signal) ### DC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) | Item | Symbol | Test Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------|------------------|------------------------------------------------------|----------------------|------|---------------------|------| | High level input voltage | V <sub>IH1</sub> | Other than X1, X2 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | V <sub>IH2</sub> | X1, X2 | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | ٧ | | Low level input voltage | V <sub>IL1</sub> | Other than X1, X2 | 0 | | 0.3 V <sub>DD</sub> | ٧ | | | V <sub>IL2</sub> | X1, X2 | 0 | | 0.4 | ٧ | | Input leak current | I <sub>LI</sub> | V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | | | 10 | μΑ | | High level output voltage | V <sub>OH</sub> | I <sub>OH</sub> = -1 mA | V <sub>DD</sub> -1.0 | | | ٧ | | Low level output voltage | V <sub>OL</sub> | I <sub>OL</sub> = 1.6 mA | | | 0.4 | ٧ | | V <sub>DD</sub> power supply current | I <sub>DD</sub> | | | | 30 | mA | | V <sub>PP</sub> power supply current | I <sub>PP</sub> | MD0 = V <sub>IL</sub> , MD1 = V <sub>IH</sub> | | | 30 | mA | Note 1: Ensure that $V_{pp}$ does not exceed +13.5V including overshoot. Note 2: Ensure that $V_{DD}$ is applied before $V_{pp}$ , and is turned off after $V_{pp}$ . ### AC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) | Item | Symbol | Note 1 | Test Conditions | MIN. | TYP. | MAX. | Unit | |----------------------------------------|----------------------------------|------------------|---------------------------------------------------------|-------|------|------|------| | Address setup time (Note 2) (to MD0 ↓) | t <sub>AS</sub> | t <sub>AS</sub> | | 2 | | | μs | | MD1 setup time (to MD0 ↓ ) | t <sub>M1S</sub> | t <sub>OES</sub> | 19 d - 19 May 20 10 10 10 10 10 10 10 10 10 10 10 10 10 | 2 | | | μs | | Data setup time (to MD0 ↓ ) | t <sub>DS</sub> | t <sub>DS</sub> | | 2 | | | μs | | Address hold time (Note 2) (to MD0 ) | t <sub>AH</sub> | t <sub>AH</sub> | | 2 | | | μs | | Data hold time (to MD0 | t <sub>DH</sub> | t <sub>DH</sub> | | 2 | | | μs | | MD0 ∤ — data output float delay time | t <sub>DF</sub> | t <sub>DF</sub> | | , 0 | | 130 | ns | | V <sub>PP</sub> setup time (to MD3 ∤ ) | t <sub>VPS</sub> | t <sub>vps</sub> | · | 2 | | | μs | | V <sub>DD</sub> setup time (to MD3 ↑ ) | t <sub>VDS</sub> | t <sub>vcs</sub> | | 2 | | | μs | | Initial program pulse width | t <sub>PW</sub> | t <sub>PW</sub> | | 0.95 | 1.0 | 1.05 | ms | | Additional program pulse width | t <sub>OPW</sub> | t <sub>OPW</sub> | | 0.95 | | 21.0 | ms | | MD0 setup time (to MD1 ) | t <sub>mos</sub> | t <sub>CES</sub> | | 2 | | | μs | | MD0 - data output delay time | t <sub>DV</sub> | t <sub>DV</sub> | MD0 = MD1 = V <sub>IL</sub> | | | 1 | μs | | MD1 hold time (to MD0 † ) | t <sub>M1H</sub> | t <sub>OEH</sub> | t <sub>M1H</sub> = t <sub>M1R</sub> ≥ 50μs | 2 | | | με | | MD1 recovery time (to MD0 ) | t <sub>M1R</sub> | t <sub>OR</sub> | | 2 | | | μs | | Program Counter reset time | t <sub>PCR</sub> | _ | | 10 | | | μs | | X1 input high/low level width | t <sub>XH</sub> ,t <sub>XL</sub> | | | 0.125 | | | μs | | X1 input frequency | f <sub>x</sub> | | | | | 4.19 | MHz | | Initial mode setting time | t, | _ | | 2 | | | μs | | MD3 setup time (to MD1 † ) | t <sub>mas</sub> | | | 2 | | | μs | ### AC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) (cont'd) | Item | Symbol | Note 1 | Test Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|------------------|----------------------------|------|------|------|------| | MD3 hold time (to MD1 ) | t <sub>мзн</sub> | | | 2 | | | μs | | MD3 setup time (to MD0 ) | t <sub>M3SR</sub> | | For program<br>memory read | 2 | | | μs | | Address (Note 2) data output delay time | t <sub>DAD</sub> | t <sub>ACC</sub> | For program<br>memory read | 2 | / | | μs | | Address (Note 2) data output hold time | t <sub>HAD</sub> | t <sub>oн</sub> | For program<br>memory read | 0 | | 130 | ns | | MD3 hold time (to MD0 † ) | t <sub>M3HR</sub> | | For program<br>memory read | 2 | | | μs | | MD3 data output float delay time | t <sub>DFR</sub> | _ | For program<br>memory read | 2 | | | μs | Note 1: Symbol for corresponding µPD27C256. Note 2: The internal address signal is incremented by 1 by the rise of the 4th X1 input, and is not connected to a pin. ### Program Memory Write Timing ### Program Memory Read Timing Note Each lead center line is located whithin 0.15mm (0.006 inchof its true position (T.P.) at maximum material condition | | L . | | |------|-------------------------|-------------------------| | ITEM | MILLIMETERS | INCHES | | Α | 23.6± <sup>0.4</sup> | 0.929± <sup>0.016</sup> | | В | 20± <sup>0.2</sup> | 0.795±0.009 | | C | 14± <sup>0.2</sup> | 0.551±0.009 | | D | 17.6± <sup>0.4</sup> | 0.693± <sup>0.016</sup> | | F | 1.0 | 0.039 | | G | 0.8 | 0.031 | | Н | 0.35± <sup>0.10</sup> | 0.014±0.004 | | I | 0.15 | 0.006 | | J | 0.8 (T.P.) | 0.031 (T.P.) | | K | 1.8± <sup>0.2</sup> | 0.071±0.008 | | L | 0.8± <sup>0.2</sup> | 0.031±0.009 | | М | $0.15\pm^{0.10}_{0.05}$ | 0.006±0.004 | | N | 0.15 | 0.006 | | Р | 2.7 | 0.106 | | Q | 0.1± <sup>0.1</sup> | 0.004± <sup>0.004</sup> | | R | 0.1± <sup>0.1</sup> | 0.004± <sup>0.004</sup> | | S | 3.0 MAX. | 0.119 MAX. | Top view ### X80KW-80A | ITEM | MILLIMETERS | INCHES | |------|----------------------|-------------------------| | В | 20.0± <sup>0.4</sup> | 0.787±0.017 | | С | 14.2± <sup>0.4</sup> | 0.559± <sup>0.016</sup> | | D | R 3.0 | R 0.118 | | E | C 0.3 | C 0.012 | | F | 12.0 | 0.472 | | G | 1.0± <sup>0.2</sup> | 0.039±0.009 | | Н | 0.51± <sup>0.1</sup> | 0.020± <sup>0.001</sup> | | J | 0.8± <sup>0.1</sup> | 0.031±0.005 | | Р | 3.8 MAX. | 0.150 MAX. | | Т | 2.14 | 0.084 | ### CHAPTER 4 µPD75328 4 BIT MICROCOMPUTER WITH L.C.D. CONTROLLER/DRIVER ### 1. OVERVIEW The $\mu$ PD75328 is a product in the series of $\mu$ COM-75X 4-bit single-chip microcomputers which contains an internal programmable LCD controller/driver and standard NEC serial bus interface, High-speed operation and high-advanced functions are more of the features. Their Products are especially enhanced as the described below, in comparison with the $\mu$ PD7514 which has contained the internal LCD controller/driver in $\mu$ PD7500 series. - ROM capacitance: Maximum 8064 words x 8 bits - RAM capacitance: 512 x 4 bits - General purpose register: Maximum 8 x 4 bits - High-speed operation: Minimum instruction execution time = 1 us - Eight interrupt sources and efficient interrupt service - Efficient instruction system which can handle 1-, 4-, or 8-bit data by each data length - Three-channel multifunction timer - Very low power consumption for clock operation in standby mode (subsystem clock consumes very little power) - Internal 6 channel 8 bit precision A/D converter ### Application Fields - Appliances: VTR's, Audio sets (CD player), etc. - Others : Cameras, Tonometers, Air conditioners, #### 1.1 Features - · 41 systematic instructions - Versatile bit manipulation instructions - Efficient 4-bit data manipulation instructions - 8-bit data transfer instructions - GETI instructions convert any 2- or 3-byte instruction into a 1-byte instruction - · High-speed operation Minimum instruction execution time = 0.95 us (f<sub>x</sub> = 4.91 MHz, at 5 V operation) - · Variable instruction execution time for low voltage, low current operation - when main system clock is selected: 0.95 us, 1.91 us, 15.3 us/4.19 MHz - when subsystem clock is selected: 122 us/32.768 khz - Program memory capacitance (ROM): - Data memory capacity (RAM): 512 x 4 bits - · General purpose registers - Eight registers for 4-bit operations: X, A, B, C, D, E, H, L - Four pairs of registers for 8-bit operations: XA, BC, DE, HL - Accumulators - One-bit accumulator (CY) - 4-bit accumulator (A) - 8-bit accumulator (XA) - 68 I/O lines - 24 LCD drive output pins - 12 segment output dedicated pins - 8 dual function pins used for both segment output and CMOS output - 4 common output pins - 8 input pins - 8 middle-voltage N-channel open drain input/output pins (8 pins for driving an LED directly) - 16 CMOS input/output pins (4 pins for driving an LED directly) - Internal pull-up resistors for 35 I/O pins - 27 pins specified by using software - 8 pins specified by using mask option #### · LCD controller/driver - Selection of the number of segments: 12, 16, or 20 (4 or 8 segments can be changed to bit output port.) - Static # - Display mode selection: - 1/2 duty (1/2 bias) 1/3 duty (1/2 bias) - 1/3 duty (1/3 bias) - 1/4 duty (1/3 bias) - Split resistor for LCD drive voltage supply can be incorporated (mask option). #### 3-channel timers - 8-bit timer/event counter - Four-stage clock source - Event counting possible - 8-bit basic interval generation Reference time generation (1.95 ms, 7.82 ms, 31.3 ms, 250 ms/4.19 MHz) It is applicable to a watchdog timer. - Watch timer - 0.5 s time interval generation Count clock source: A change can be made between main and subsystem clocks Watch rapid feed mode (3.9 ms time interval generation) Buzzer output can be made. (2 kHz) #### · 8-bit serial interface - It provides three modes: - 3-line serial I/O mode - 2-line serial I/O mode - SBI mode - The serial transfer data top can be changed between the least and most significant bits (LSB and MSB). - · 8-bit A/D converter is contained - Analog input: six channels - A/D conversion rate: 40.1 us at f<sub>x</sub> = 4.19 MHz - A/D operation range: $V_{DD}$ = 3..5 to 6.0 (V) AV<sub>REF</sub> = 2.5 to $V_{DD}$ (V), Ta = -10 to + 80 °C - 16-bit bit sequential buffer (special bit manipulation memory): - Suitable for remote control applications. - · Clock output function - Timer/event counter output (PTO0): Outputs a square wave of any desired frequency - Clock output (PCL) : $\phi$ , f,/2<sup>3</sup>, f,/2<sup>4</sup>, f,2<sup>6</sup> - Buzzer output (BUZ): 2 kHz (mâin system clock 4.19 MHz at operation/subsystem clock 32.7 kHz at operation) - · Vectored interrupt function - Three external vectored interrupts Both rising and falling edge detection interrupt (INT4) Detection edge programmable interrupt with noise elimination function (INT0) Detection edge programmable interrupt (INT1) - External rising edge detection/parallel port edge detection test input (INT2) - -Three internal vectored interrupts: Timer/event counter 0 interrupt (INTT0) Basic interval timer interrupt (INTBT) Serial interface interrupt (INTCSI -Watch test input (INTW) - Two interal oscillators for system clock generaion - Ceramic or crystel oscillator for main system clock oscillation: 4.194304 MHz Standard - Crystal oscillator for subsystem clock oscillation: 32.768 kHz Standard - · Standby operation - STOP mode: Main system clock oscillation stops. HALT mode: System clock oscillation continues. (CPU clock oscillation continues.) - · CMOS ### 1.2 Ordering Information | Ordering code | Package | Internal ROM | | | |--------------------|---------------------------------|--------------|--|--| | μPD75328GC-xxx-3B9 | 80-pin plastic QFP (bent leads) | Mask ROM | | | Remark: xxx shows the code number of the mask ROM and option specification ### 1.3 List of Family Product Functions | Item | μPD75328 | μPD75P328 | | |----------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------|--| | Program memory | • Mask ROM<br>• 8064 x 8 bits<br>• 0000H-1F7FH | • One time PROM<br>• 8064 x 8 bits<br>• 0000H-1F7FH | | | Pull-up resistor in Port 4, 5 | Mask option | Not included | | | Split resistor for LCD drive power supply | | | | | Feed back resistor for subsystem clock oscillation | Mask option | Not included | | | Pin connection | V <sub>PP</sub> pin, one time PROM program pin not included | V <sub>PP</sub> pin, one time PROM program pin included | | | Supply voltage range | 2.7V - 6.0V | 5V ± 15% | | | Package | 80-pin plastic QFP (bent leads) | | | ## 1.5 Pin Connection (Top view) | FU | J-U3 | ٠ | Port o | A V <sub>SS</sub> | : Analog Ground | _ | |-----|------|---|-----------------|-------------------|---------------------------------------|---| | P10 | 0-13 | : | Port 1 | AN0-5 | : Analog Input 0-5 | | | P20 | 0-23 | : | Port 2 | S12-31 | : Segment Output 12-31 | | | P30 | 0-33 | : | Port 3 | COM0-3 | : Common Output 0-3 | | | P40 | 0-43 | : | Port 4 | $V_{LC0-2}$ | : LCD Power Supply 0-2 | | | P50 | 0-53 | : | Port 5 | BIĂŠ | : LCD Power Supply Bias Control | | | P60 | 0-63 | : | Port 6 | LCDCL | : LCD Clock | | | P70 | 0-73 | : | Port 7 | SYNC | : LCD Synchronization | | | P80 | 0-83 | : | Port 8 | TIO | : Timer Input 0 | | | BP | 0-7 | : | Bit Port | PTO0 | : Programmable Timer Output 0 | | | KR | 0-7 | : | Key Return | BUZ | : Buzzer Clock | | | SC | K | : | Serial Clock | PCL | : Programmable Clock | | | SI | | : | Serial Input | INTO, 1, 4 | : External Vectored Interrupt 0, 1, 4 | | | SO | | : | Serial Output | INT2 | : External Test Input 2 | | | SB | 0, 1 | : | Serial Bus 0, 1 | X1, 2 | : Main System Clock Oscillation 1, 2 | | | RE | SET | : | Reset Input | XT1, 2 | : Subsystem Clock Oscillation 1, 2 | | | | | | | | | | A V<sub>REF</sub> : Analog Reference NC/V<sub>PP</sub>\* : No Connection $<sup>^{\</sup>star}$ When using the same socket for $\mu PD75P328$ and $\mu PD75328,$ $V_{pp}$ pin has to be set to $V_{DD}$ in operating mode! #### 2. PIN FUNCTIONS ## 2.1 Input and output ports 2.1.1 P00-P03 (port 0) - Input Pins Also Used for INT4, SCK, SO/SB0, SI/SB1 P10-P13 (port 1) - Input Pins Also Used for INT0, INT1, INT2, and TI0 P00-P03 and P10-P13 are pins for 4-bit input port (port 0 and 1). - (1) The P00-P03 pins are also used for the INT4 pin (vectored interrupt input) and the SCK, SO/SB0, and SI/SB1 pin (serial interfaceb output). - (2) The P10-P13 pins are also used for the INT0 and INT1 pins (vectored interrupt input), the INT2 pin (edge detection test input) and the TI0 pin (external event pulse to the timer/event counter). The state of each pin P00-P03 and P10-P13 can always be input regardless of the condition of any of the pins INT4, SCK, SO/SB0, SI/SB1, INT0, INT1, INT2, and TI0. To prevent noise from causing a malfunction, a Schmitt trigger input is applied to port 0 P00/INT4, P01/SCK, P02/SO/SB0, P03/SI/SB1 input and port 1 pins. In addition, P10 is provided with a noise removal circuit. (For details, see 6.3 (2).) An internal pull-up resistor can be specified for port 0 in 3-bit units (P01-P03) and for port 1 in 4-bit units (P10-P13) by using the software-operated pull-up resistor specification register group A. When the RESET signal is generated, every pin is placed in input port mode. 2.1.2 P20-P23 (port 2) - Input/Output Pins Also Used for PTO0, PCL, and BUZ P30-P33 (port 3) - Input/Output Pins Also Used for LCDCL and SYNC. P40-P43 (port 4) - and P50-53 (port 5) - N-Channel Open Drain Medium-Voltage (10 V) P60-P63 (port 6), P70-73 (port 7), P80 - P83 (port 8) - 3-State Input/Output P20-P23, P30-P33, P40-P43, P50-P53, P60-P63, P70-P73 and P80-P83 are 4-bit input/output ports with output latches. - (1) The P20-P23 pins are also used for the PTO0 pin timer/event counter output), the PCL pin (programmable clock output), and the BUZ pin (fixed frequency output). - (2) The P30-P33 pins are also used for the LCDCL pin (LCD external extended driver driving clock) and the SYNC pin (LCD) external extended driver synchronizing clock). - (3) The P60-P63 and P70-P73 pins are also used for the KR0-KR3 and KR4-KR7 pins (key interrupt input). Port 3 has high-current output, enabling an LED to be driven directly. Ports 4 and 5 outputs are N-channel open drain medium-voltage (10 V) and high-current, enabling an LED to be driven directly. The input/output mode of each port is selected by using the port mode register. The mode of port 2, 4, 5, 7 or 8 can be specified in 4-bit units, and that of port 3 or 6 bitwise. An internal pull-up resistor can be specified for ports 2, 3, 6, 7 and 8 in 4-bit units by using software to operate the pullup resistor specification register (POGA, POGB). It can be specified for ports 4 and 5 bitwise by using the mask option. Ports 4 and 5 (6 and 7) can be paired for input/output in 8-bit units. When the RESET signal is generated, ports 2, 3, 6, 7 and 8 are placed in input mode (output high impendance) and ports 4 and 5 are set to a high level (when internal pull-up register is contained) or to high impendance. ### 2.1.3 BP0-BP7 - Output Pins Also Used for S24-S31 (LCD Controller/Driver Segment Signal Output) BP0-BP7 are bit port 0-7 output pins (each port is a 1-bit output port with output latch). The BP0-BP7 pins are also used for the S24-S31 pins (LCD controller/driver segment output signal output pins). #### 2.1.4 TIO - Input Pin Also Used for Port 1 TI0 is an external event pulse input pin for the programmable timer/event counter. The pin is Schmitt trigger input. ## 2.1.5 PTO0 - Output Pin Also Used for Port 2 PTO0 is a programmable timer/event counter output pin which outputs square wave pulses. To output a programmable timer/event counter signal, the P20 output latch is cleared and the port 2 bit of the port mode register is set to 1 (output mode). Output is cleared by execution of the timer start instruction. ## 2.1.6 PCL - Output Pin Also Used for Port 2 PCL is a programmable clock output pin used to supply clocks to peripheral LSI devices such as a slave microcomputer and an A/D converter. When the RESET signal is generated, the clock mode register (CLOM) is cleared, clock output is inhibited, and the normal port operation mode is set. #### 2.1.7 BUZ - Output Pin Also Used for Port 2 BUZ is a fixed frequency output pin. Fixed frequency (2.048 kHz) output is used for buzzer sounding and system clock oscillation frequency trimming. The BUZ pin, also used for the P23 pin, is validated only when bit 7 (WM7) of the watch mode register (WM) is set to 1. When the RESET signal is generated, WM7 is cleared and the normal port operation mode is set. ## 2.1.8 SCK, SO/SB0, and SI/SB1 - 3-State Input/Output Pins Also Used for Port 0 SCK, SO/SB0, and SI/SB1 are input/output pins for serial interface and operate according to how the serial operation mode register (CSIM) is set. When the RESET signal is generated, serial interface operation is stopped and the pins are used for port 0 (input port). Every pin is Schmitt trigger input. #### 2.1.9 INT4 - Input Pin also Used for Port 0. INT4 is an external vectored interrupt input pin (both rising and falling edged active). When the signal input to the pin changes from low to high state or from high to low state, the interrupt request flag is set. INT4 is for asynchronous input. When a signal having a given high or low level duration is input, it is acknowledged independently of the CPU operation clock. INT4 can also be used to release the STOP or HALT mode. It is Schmitt trigger input. #### 2.1.10 INT0 and INT1 - Input Pins Also Used for Port 1 INTO and INT1 are edge detection vectored interrupt input pins. INTO has the noise removal function. Detected edge selection can be made using edge detection mode registers (IMO and IM1). - (1) INTO (IMO bits 0 and 1) - (a) Rising edge active - (b) Falling edge active - (c) Both rising and falling edges active - (d) External interrupt signal input inhibited - (2) INT1 (IM1 bit 0) - (a) Rising edge active - (b) Falling edge active INTO has the noise removal function; sampling clocks for noise removal can be changed two stages. The acknowledged signal width varies depending on CPU clock operation. INT1 is for asynchronous input. When a signal having a given high level duration is input, it is acknowledged independently of the CPU clock operation. When the RESET signal is generated, IM0 and IM1 are cleared and rising edge active is selected. INTO and INT1 are Schmitt trigger inputs. ## 2.1.11 INT2 - Input Pin Also Used for Port 1 INT2 is an external test input pin (both rising and falling edges active). When INT2 is selected by using the edge detection mode register (IM2) and the signal input to the INT2 pin transits from low to high state, the internal test flag (IRQ2) is set. INT2 is for asynchronous input. When a signal having a given high level duration is input, it is acknowledged independently of the CPU clock operation. When the RESET signal is generated, IM2 is cleared and the test flag (IRQ2) is set by inputting the rising edge to the INT2 pin. # 2.1.12 KR0-KR3 - Input Pins Also Used for Port 6 KR4-KR7 - Input Pins Also Used for Port 7 KR0-KR7 are key interrupt (parallel falling edge detection interrupt) input pins. The interrupt format can be specified by setting the edge detection mode register (IM2). When the RESET signal is generated, the pins are placed in port 6 and 7 input mode. #### 2.1.13 S12-S23 - Output S24-S31 - Output Pins Also Used for Bit Ports 0-7 S12-S31 are segment signal output pins for directly driving LCD segments (front electrodes). Static, 2 or 3 time division (1/2 bias law), or 3 or 4 time division (1/3 bias law) driving is performed. S0-S23 are segment-only output pins. S24-S31 are also used for the bit port 0-7 output; which mode the pins are used for, is specified by using the dislay mode register (LCDM). 2.1.14 COM0-COM3 - Output COM0-COM3 are common signal output pins for directly driving the LCD common pins (rear electrodes). Common signals are output when static (COM0, COM1, COM2, COM3 output), while driving by 1/2 bias law 2 time division (COM0, COM1 output), while driving by 3 time division (COM0, COM1, COM2 output), while driving by 1/3 bias law 3 time division (COM0, COM1, COM2, COM3 output) is performed. 2.1.15 V<sub>LC0</sub>-V<sub>LC2</sub> $V_{LC0}$ $V_{LC2}$ are power supply pins to drive the LCD. The $\mu$ PD75328 allows split-resistor incorporation in the $V_{LC0}$ $V_{LC2}$ pins so that LCD drive power can be supplied according to the bias law without using an external split resistor. (Mask option) #### 2.1.16 BIAS BIAS is an LCD power supply bias control pin. To deal with various LCD drive voltages, the BIAS pin is connected to the $V_{LCO}$ pin to change the resistor split ratio. By connecting an external resistor, the BIAS pin can be used together with the $V_{LCO}$ - $V_{LC2}$ and V<sub>SS</sub> pins for fine adjustment of the LCD drive supply voltage. #### 2.1.17 LCDCL LCDCL is a clock output pin for driving an external LCD extension driver. #### 2.1.18 SYNC SYNC is a clock output pin for synchronizing an external LCD extension driver. #### 2.1.19 AN0-AN5 - Input ANO-AN5 are six analog signal input pins to A/D converter. # 2.1.20 AV<sub>REF</sub> AV<sub>REE</sub> is an A/D converter reference voltage input pin. 2.1.21 $\text{AV}_{\text{SS}}$ AV s is an A/D converter GND pin. ## 2.1.22 X1 and X2 X1 and X2 are connection pins for the main system clock crystal / ceramic oscillator. External clocks can also be input. ## Crystal ceramic oscillator External clock (b) ## 2.1.23 XT1 and XT2 XT1 and XT2 are crystal connection pins for the subsystem clock oscillation. External clocks can also be input. 2.1.24 RESET RESET is an active low reset input pin. RESET is for asynchronous input. When a signal having a given low level duration is input independently of the operation clock, the RESET signal is generated and the system is reset overriding all other operations. It is used for normal CPU initialization / start-up and also to release the standby (STOP or HALT) mode. RESET is a Schnitt trigger input. 2.1.25 V<sub>DD</sub> V<sub>DD</sub> is a positive power supply pin. 2.1.26 V<sub>ss</sub> V<sub>SS</sub> is a ground potential. ## 2.2 Pin Function List (1) Normal operation mode Table 2.2-1 Digital Input / Output Port Pin Function List | Pin name | I/O | Also<br>used for: | Function | | 8-bit<br>I/O | When reset | I/O circuit<br>type (Note 1) | | |---------------------|-------|-------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------|------------------------------------------|--| | P00 | ı | INT4 | 4-bit input port ( | nort (I) | | | В | | | P01 | I/O | SCK | Internal pull-up | esistors | × | Input | (F)− A | | | P02 | I/O | SO/SBO | can be specified | | ^ | input | _ Б- В | | | P03 | 1/0 | SI/SB1 | in 3-bit units by using software | | | | (M)− C | | | P10 | | INT0 | | With noise removal function | | | | | | P11 | ] , | INT1 | 4-bit input port ( | | × | Input | (B)- C | | | P12 | ] '' | INT2 | Internal pull-up | | | l input | | | | P13 | | TI0 | | an be specified for P10-P13 4-bit units by using software | | | | | | P20 | | PTO0 | 4-bit input/outpu | t nort (nort 2) | | Input | | | | P21 | 1/0 | _ | Internal pull-up | resistor can be | | | E-B | | | P22 | ] 1/0 | PCL | specified for P20<br>units by using so | | × | input | E-B | | | P23 | | BUZ | units by using software. | | | | | | | P30 | | LCDCL | Programmable 4-bit input/output port (port 3). Input or output mode can be selected bitwise. | | | | | | | P31 | | SYNC | | | | | en e | | | P32 | 1/0 | _ | Internal pull-up i | | × | Input | E – B | | | P33 | | _ | specified for P30-P33 in 4-bit units by using software.(Note 2) | | | | | | | P40-P43<br>(Note 2) | 1/0 | | input/output port<br>Pull-up resistor (<br>incorporated bits<br>option). | N-channel open drain 4-bit<br>input/output port (port 4).<br>Pull-up resistor can be<br>incorporated bitwise (mask | | High level (when<br>pull-up resistor<br>is incorporated)<br>or high<br>impendance | М | | | P50-P53<br>(Note 2) | I/O | -<br>- | N-channel open input/output port Pull-up resistor incorporated bits option). | t (port 4).<br>can be<br>wise (mask | 0 | High level (when pull-up resistor is incorporated) or high impendance | М | | (to be continued) Table 2.2-1 Digital Input / Output Port Pin Function List (cont`d) | Pin name | 1/0 | Also<br>used for | Function | 8-bit<br>I/O | When reset | I/O circuit<br>type (Note 1) | |----------|------|------------------|------------------------------------------------------------------------------------------|--------------|----------------|------------------------------| | P60 | | KR0 | Programmable 4-bit input/output port (port 6). Input or output mode | | | | | P61 | ] ,, | KR1 | can be selected bitwise. | | lmm.uk | (F)- A | | P62 | 1/0 | KR2 | Internal pull-up resistor can be | 1 | Input | ( C - A | | P63 | | KR3 | specified for P60-P63 in 4-bit units by using software. | 0 | , | | | P70 | | KR4 | 4 5 1 5 1 7 1 7 1 | 1 | | | | P71 | 1/0 | KR5 | 4-bit input/output port (port 7). Internal pull-up resistor can be | | Input | (F)- A | | P72 | 1/0 | KR6 | specified for P70-P73 in 4-bit units by using software. | | | 0-1 | | P73 | KR7 | | units by using software. | | - | Land to the | | P80 | | | 4-bit input/output port (Port 8). | | | | | P81 | | - " | Internal pull-up resistor can be specified for P80-P83 in 4-bit units by using software. | × | Input | | | P82 | 1/0 | | | ^ | | E-B | | P83 | | | urills by using software. | | - | | | BP0 | | S24 | | | | | | BP1 | | S25 | | | | | | BP2 | 0 | S26 | | | Note 3 | | | BP3 | | S27 | 1-bit output ports (bit ports). x | × | | G-C | | BP4 | | S28 | The pins are also used for the segment output pins. | ^ | Note 3 | 4-0 | | BP5 | | S29 | | | | | | BP6 | 0 | S30 | | | and the second | | | BP7 | | S31 | | | | | Note 1: The O mark denotes Schmitt trigger input Note 2: LED can be driven directly Note 3: BP0-7 select $V_{LC1}$ as the input source. The output level is changed by the external circuit of BP0-7 and V<sub>LC1</sub>. Example: Since BP0-BP7 are connected to each other through the µPD75328 as illustrated below, the BP0-BP7 output level is determined by the resistance value of R1, R2, R3. Table 2.2-2 Pin Function List other than Port Pins | Pin name | 1/0 | Also<br>used for: | Function | | When reset | I/O circuit<br>type (Note 1) | |------------------------------------|-----|-------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------|--------------|------------------------------| | TI0 | 1 | P13 | External event pulse input pin to time | | <b>®</b> −c | | | PT00 | 1/0 | P20 | Timer / event counter output pin. | Input | E-B | | | PCL | I/O | P22 | Clock output pin. | · | Input | E-B | | BUZ | 1/0 | P23 | Fixed frequency output pin (for buzze trimming). | Input | E-B | | | SCK | I/O | P01 | Serial clock input / output pin. | | Input | <b>(F)</b> - A | | SO/SB0 | I/O | P02 | Serial data output pin.<br>Serial bus input / output pin. | | Input | <b>(</b> F)– В | | SI/SB1 | I/O | P03 | Serial data input pin.<br>Serial bus input / output pin. | | Input | <b>M</b> -c | | INT4 | l | P00 | Edge detection vectored interrupt inp of both rising and falling edges is acti | | | B | | INT0 | 1 | P10 | Edge detection vectored interrupt input pin (detected edge can be | | | - B-c | | INT1 | | P11 | selected). | Asynchronous | | | | INT2 | ı | P12 | Edge detection testable input pin asynchronous (rising edge is detected). | | | <b>®</b> −¢ | | KR0-KR3 | I/O | P60-P63 | Parallel falling edge detection testabl pins. | Input | <b>€</b> - A | | | KR4-KR7 | I/O | P70-P73 | Parallel falling edge detection testabl pins. | Input | <b>€</b> -A | | | S12-S23 | 0 | - | Segment signal output pins. | | Note 4 | G-A | | S24-S31 | 0 | BP0-7 | Segment signal output pins. | | Note 4 | G-C | | СОМО-СОМЗ | 0 | _ | Common signal output pins. | * * | Note 4 | G-B | | V <sub>LC0</sub> -V <sub>LC2</sub> | - | _ | LCD drive power supply pins. Internate be used (mask option). | l split resistor can | - | | | BIAS | 0 | _ | Output pin to cut external split resisto | r. | Note 5 | | | LCDCL<br>(Note 3) | I/O | P30 | Clock output pin for external extension | n driver. | Input | E – B | | SYNC<br>(Note 3) | 1/0 | P31 | Clock output pin for synchronizing ex driver. | ternal extension | Input | E – B | | AN0-AN5 | ı | _ | 6-bit analog input pins to A/D convert | er. | | Y | | AV <sub>REF</sub> | ı | _ | A/D converter reference voltage inpu | t pins. | | Z | | AV <sub>SS</sub> | ı | | A/D converter reference GND input p | ins. | | | | X1, X2 | | _ | Connection pins for main system cloc<br>oscillator. When external clock is use<br>and its opposite phase is input to X2. | _ | - | | | XT1 | 1 | _ | Subsystem clock oscillation crystal or<br>When external clock is used, it is input | ut to XT1, and | - | _ | | XT2 | | | XT2 is not connected. XT1 can be us (test) pin. | ea tor 1-bit input | _ | _ | | RESET | 1 | | System reset input pin. | | - | B | Table 2.2-2 Pin Function List other than Port Pins | Pin name | 1/0 | Also<br>used for: | Function | When reset | I/O circuit<br>type (Note 1) | |-----------------|-----|-------------------|----------------------------|------------|------------------------------| | NC<br>(Note 2) | 1 | | No connection | 1 | - | | V <sub>DD</sub> | - | | Positive power supply pin. | _ | - | | V <sub>ss</sub> | - | | Ground potential pin. | | | ## Notes: - 1. The mark denotes Schmitt trigger input. - 2. Connected the NC pin to $V_{DD}$ , when $\mu PD75P328$ and printed board are also shared with. - 3. The pins are provided for future system expansion; at present they are used only for the P30 and P31 pins - 4. For each display output, the following $V_{\text{LCX}}$ are selected as input sources: S12-31 : V<sub>LC1</sub> COM0-COM2 : V<sub>LC2</sub> COM3 : $V_{LC0}$ However, the display output level varies depending on the display output and $V_{LCX}$ external circuit. Example: Since BP0-BP7 are connected to each other through the $\mu$ PD75328 as illustrated below, the BP0-BP7 output level is determined by the resistance value of R1, R2, R3. μPD75328 5. When internal split resistor is contained : Low level When internal split resistor is not contained: High impedance ## 2.3 Pin Input / Output Circuits The $\mu\text{PD75328}$ pin input / output circuits are shown in schematic drawings. ## (1) Type A (for Type E - B) CMOS standard input buffer (2) Type B Schmitt trigger input with hysteresis characteristic (3) Type B - C (4) Type D (for Type E - B, F - A) Push-pull output where output can be placed in high impedance (both P and N channels are turned off). (5) Type E - B P.U.R.: Pull-Up Resistor (6) Type F - A P.U.R.: Pull-Up Resistor (7) Type F - B P.U.R.: Pull-Up Resistor (8) Type G - A (9) Type G - B (10) Type G - C (11) Type M P.U.R.: Pull-Up Resistor ## (12) Type M - C P.U.R.: Pull-Up Resistor (13) Type Y (14) Type Z ## 2.4 Processing of Unused Pins ## Table 2.4-1 Unused Pins Lists | Pin | Recommended connection | | | | |------------------------------------|--------------------------------------------------------------------------------------------------------------------|--|--|--| | P00 / INT4 | Connect to V <sub>SS</sub> . | | | | | P01 / SCK | | | | | | P02 / SO /SB0 | Connect to V <sub>SS</sub> or V <sub>DD</sub> . | | | | | P03 / SI / SB1 | | | | | | P10 / INTO-P12 / INT2 | 0 | | | | | P13 / TI0 | Connect to V <sub>SS</sub> . | | | | | P20 / PTO0 | | | | | | P21 | | | | | | P22 / PCL | | | | | | P23 / BUZ | | | | | | P30-P33 | Input mode: Connect to V <sub>SS</sub> or V <sub>DD</sub> . | | | | | P40-P43 | Output mode: Do not connect. | | | | | P50-P53 | | | | | | P60-P63 | | | | | | P70-P73 | | | | | | P80-P83 | | | | | | S12-S23 | | | | | | S24 / BP0-S31 / BP7 | Do not connect. | | | | | СОМ0-СОМ3 | | | | | | V <sub>LC0</sub> -V <sub>LC3</sub> | Connect to V <sub>SS</sub> . | | | | | BIAS | Only when all of $V_{\rm LCO} - V_{\rm LC2}$ are unused, connect BIAS to $V_{\rm SS}$ ; otherwise, do not connect. | | | | | XT1 | Connect XT1 to V <sub>SS</sub> or V <sub>DD</sub> . | | | | | XT2 | Do not connect XT2. | | | | ## 2.5 Mask Option Selection The pins contain the mask option function as listed in Table 2.5-1. However, mask option is not contained in the $\mu$ PD75P328. Table 2.5-1 Mask option selection | Pin names | Mask option | |-------------------------------------------|-----------------------------------------------------------------------------------------------| | P40–P43,<br>P50–P53 | . Pull-up resistor is included.<br>specified bit-wise.<br>. Pull-up resistor is not included. | | Split resistor for LCD drive power supply | . Split resistor is included Split resistor is not included. | ## 3. ARCHITECTURE AND MEMORY MAP The $\mu$ COM-75X architecture for the $\mu$ PD75328 adopts data memory bank configuration and memory mapped I / O to provide features such as: - Internal RAM with maximum of 4K words x four bits (12-bit addresses) - Peripheral hardware extensibility This chapter covers these topics. ## 3.1 Data Memory Bank Configuration and Addressing Modes #### 3.1.1 Data memory bank configuration A general purpose static RAM (492 words x four bits) is incorporated in data memory space addresses 000H to 1DFH, and display data memory (20 words x four bits) is incorporated in adresses 1E0H to 1FFH. Peripheral hardware such as input/output ports and timers is allocated to addresses F80H to FFFH. To address the data memory space (4K words x four bits) with 12-bit addresses, the µPD75328 adopts a memory bank configuration where the low-order eight bits of an address are specified either directly or indirectly by using an instruction, and the high-order four bits of an address are specified by using a memory bank. To specify the memory bank (MB), two hardware devices are incorporated in the $\mu PD75328$ : - Memory bank enable flag (MBE) - Memory bank selection register (MBS) MBS is a register used to select a memory bank. The µPD75328 allows 0, 1, or 15 to be set in MBS. MBE is a flag used to determine whether or not the memory bank selected by using MBS is validated. As shown in Fig. 3.1–1, when MBE is set to 0, the specified memory bank is fixed regardless of how MBS is set; when MBE is set to 1, memory bank switching can be performed to extend data memory space by setting MBS. In data memory space addressing, normally MBE is set to 1, and the data memory area of the memory bank specified by using MBS is handled. An efficient program can be prepared by using MBE = 0 mode and MBE = 1 mode appropriately in each process of the program. | | Applicable program processing | Effects | | |--------------|------------------------------------------------------------------------------------------------|--------------------------------------------|--| | | ° Interrupt service | MBS save and restore are made unnecessary. | | | MBE = 0 mode | ° Repetitive processing of internal<br>hardware operation and general<br>purpose RAM operation | MBS change is made unecessary. | | | | ° Subroutine processing | MBS save and restore are made unnecessary. | | | MBE = 1 mode | ° Normal program processing | | | Figure 3.1-1: Proper Use of MBE = 0 and MBE = 1 Modes MBE is saved or restored automatically during subroutine processing and can be changed as desired. When interrupt service is made, MBE is automatically saved or restored. MBE during interrupt service can also be specified at the same time interrupt service starts by setting the interrupt vector table. Thus, it is useful for high-speed interrupt service. To change the MBS setting in subroutine processing or interrupt service, MBS is saved and restored by using PUSH and POP instructions. MBE is set and reset by using SET1 and CLR1 instructions. MBS is set by using the SEL instruction. Example 1: To clear MBE and fix memory bank CLR1 MBE ; MBE ◆ 0 Example 2: To select memory bank 1 SET1 MBE; MBE ◀ 1 SEL MB1; MBS ◀ 1 ## 3.1.2 Data memory addressing modes The $\mu$ COM-75X architecture adopted for the $\mu$ PD75328 provides seven addressing modes, as shown in Fig. 3.1–2, for efficiently addressing the data memory space for each bit length of data to be processed. ## (1) 1-bit direct adressing (mem. bit) This addressing mode directly specifies each bit in all the data memory space by using the instruction operand. When MBE is set to 0, the specified memory bank (MB) is fixed to memory bank 0 (MB0) if the address specified in the operand is 00H-7FH; it is fixed to memory bank 15 (MB15) if the address specified in the operand is 80H-FFH. Thus, when MBE is set to 0, both the general purpose RAM area (000H-07FH) and peripheral hardware area (F80H-FFFH) can be addressed. When MBE is set to 1, any memory bank can be specified by setting MBS; data memory space that can be specified can be extended. The 1-bit direct addressing mode is applicable to bit set and reset instructions (SET1 and CLR1) and bit test instructions (SKT and SKF). Example: To set FLAG1, reset FLAG2, and test whether or not FLAG3 is set to 0. FLAG1 EQU 03FH.1 ; 3FH address bit 1 FLAG2 EQU 087H.2 ; 87H address bit 2 FLAG3 EQU 0A7H.0 ; A7H address bit 0 SET1 MBE ; MBE 1 SEL MB0 ; MBS 1 SET1 FLAG1 ; FLAG1 1 CLR1 FLAG2 ; FLAG2 1 SKF FLAG3 ; FLAG3 = 0? Figure 3.1–2 Data Memory Configuration and Addressing Range of each Addressing Mode | Addressing mode | Representation format | Specified address | | | | |------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 1-bit direct<br>addressing | mem. bit | Bit indicated by a bit at the address indicated by MB and mem. However, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FFH When MBE = 1, MB = MBS | | | | | 4-bit direct addressing | | Address indicated by MB and mem. However, MBE = 0, MB = 0 when mem = 00H-7FH MB = 15 when mem = 80H-FH When MBE = 1, MB = MBS | | | | | 8-bit direct addressing | mem | Address indicated by MB and mem (mem is an even address). However, $ \left\{ \begin{array}{ll} MBE=0, & MB=0 \text{ when mem} = 00H\text{-}7FH \\ MB=15 \text{ when mem} = 80H\text{-}FFH \\ When MBE=1, MB=MBS \end{array} \right. $ | | | | | | @ HL | Address indicated by MB and HL. However, MB = MBE • MBS | | | | | 4-bit register indirect addressing | @ DE | Memory bank 0 address indicated by DE | | | | | g | @ DL | Memory bank 0 address indicated by DL | | | | | 8-bit register indirect addressing | @ HL | Address indicated by MB and HL (the L register contains an even number). However, MB = MBE $\bullet$ MBS | | | | | | fmem. bit | Bit indicated by a bit at the address indicated by fmem. However, fmem { FB0H-FBFH (hardware related to interrupt) FF0H-FFFH (I/O port) | | | | | Bit manipulation addressing | pmem. @ L | Bit indicated by the low-order two bits of the L register at the address indicated by the high-order 10 bits of pmem and the high-order two bits of the L register. However, pmem = FC0H-FFFH | | | | | <u> </u> | @ H + mem. bit | Bit indicated by a bit at the address indicated by MB, H, and the low-order four bits of mem. However, MB = MBE • MBS | | | | | Stack addressing | | Memory bank 0 address indicated by SP. | | | | Figure 3.1–3 Addressing Modes ## (2) 4-bit direct addressing (mem) This addressing mode directly specifies all the data memory space in 4-bit units by using the instruction operand. As with the 1-bit direct addressing mode, when MBE is set to 0, the 4-bit direct address mode allows that only the general purpose RAM area (000H-07FH) and peripherial hardware area (F80H-FFFH) can be specified. When MBE is set to 1, any memory bank (MB) can be specified by setting MBS and the data memory space that can be specified is extended to all the The 4-bit direct addressing mode is applicable to the MOV, XCH, INCS, IN, and OUT instructions. Example 1: To input port 4 and store in "DATA1". DATA1 EQU 5FH "DATA1" is address 5HF. CLR<sub>1</sub> MBE<del>▼</del> 0 MBF A, PORT4 IN A<del><</del> PORT4 MOV DATA1, A (DATA1) <del>←</del> A Example 2: To output data in "BUFF" to port 5. **BUFF EQU** 11AH "BUFF" is address 11AH SET1 MRE MBE<del></del>← 1 SEL MB1 MBS<del><−</del> 1 MOV A. BUFF A<del><</del> (BUFF) SEL MB15 MBS<del><---</del> 15 OUT PORT5. A PORT5<del></del> A ## Caution: If data related to the input /output ports is stored in general purpose RAM of bank 1 as in this example, the program is made less efficient. If data related to the input /output ports is stored in addresses 00H-7FH of bank 0, a program can be prepared without changing MBS as in Example 1. ## (3) 8-bit direct addressing (mem) This addressing mode directly specifies all the data memory space in 8 bit units by using the instruction operand. Only even address can be specified in the mem operand. The 4-bit data at the address specified in the operand and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register pair) for 8-bit processing. The memory banks specified in the addressing mode are the same as in the 4-bit direct addressing mode. The 8-bit direct addressing mode is applicable to the MOV, XCH, IN, and OUT instructions. Example 1: To transfer 8-bit data in ports 4 and 5 to addresses 20H and 21H. DATA EQU 020H CLR<sub>1</sub> MRF X → port 5, A → port 4 IN XA, PORT4; MOV DATA, XA Example 2: To read 8-bit data input to the serial interface shift register (SIO), set transfer data, and start of transfer. SEL **MB15** MBS**→** 15 XCH XA, SIO XA (SIO) ## (4) 4-bit register indirect addressing (@rpa) This addressing mode indirectly specifies the data memory space in 4-bit units by using the data pointer (general purpose register pair) specified in the instruction operand. The data pointers are the HL register pair, which enables all the data memory space to be specified according to MB = MBE • MBS specification, and the DE and DL register pairs, which always indicate memory bank 0 regardless of how MBE and MBS are set. Efficient programs can be prepared by using the data memory bank to be used. Example: To transfer data at 50H-57H to 110H-117H. ``` DATA1 EQU 57H DATA2 EQU 117H SET1 MBE SEL MB<sub>1</sub> MOV D, #DATA1 SHR 4 MOV HL, #DATA2 AND 0FFH; HL 17H LOOP: MOV A. @DL ; A ← (HL) ; L ← L-1 XCH A, @HL DECS BR LOOP ``` The addressing mode using the HL register pair for the data pointer has wide applications such as data transfer, operation, comparison, and input / output. The addressing mode using the DE or DL register pair is applicable to the MOV and XCH instructions. As shown in Fig. 3.1–4, data memory space addresses can be updated as desired by combining the addressing mode with general purpose register (or register pair) increment and decrement instructions. Example 1: To compare data at 50H-57H with data at 110H-117H. ``` DATA1 EQU 57H DATA2 EQU 117H SET1 MBE SEL MB<sub>1</sub> MOV D, #DATA1 SHR 4 MOV HL, #DATA2 AND 0FFH LOOP: MOV A, @DL SKE A, @HL A = (HL)? BR NO NO DECS L YES, L← L-1 BR LOOP ``` Example 2: To clear data memory area 04H-FFH. ``` SEL MB0 MOV XA, #00H MOV L. #04H LOOP: MOV @HL, A (HL)<del>◀</del> A INCS HL L ← L+1 BR LOOP INCS н : H → H+1 BR LOOP ``` Figure 3.1-4 General Purpose RAM Address Update Method ## (5) 8-bit register indirect addressing (@HL) This addressing mode indirectly specifies all the data memory space in 8-bit units by using the data pointer (HL register pair). The 4-bit data at the address setting data pointer bit 0 (L register bit 0) to 0 and the 4-bit data at the address + 1 are paired and transferred to the 8-bit accumulator (XA register) for 8-bit processing. The memory banks specified in the addressing mode are the same as those when the HL register is specified in the 4-bit register indirect addressing mode (MB = MBE • MBS). The 8-bit register indirect addressing mode is applicable to the MOV, XCH, and SKE Instructions. Example 1: To compare the count register (T0) value of timer / event counter 0 with data at addresses 30H and 31H for equality. ``` DATA EQU 30H CLR1 MBF HL, #DATA MOV MOV XA, TO XA ← count register 0 SKE A, @HL A = (HL)? BR NO INCS 1 MOV A, X ``` A = (HL)? ## (6) Bit manipulation addressing SKE This addressing mode is used to perform bit manipulations such as Boolean operation or bit transfer on any bit in all of the data memory space. Although the 1-bit direct addressing mode is applicable only to the bit set, reset, and test instructions, the bit manipulation addressing mode enables bit manipulations such as Boolean operations by using the AND1, OR1, and XOR1 instructions and allows bit test and bit reset by using the SKTCLR instructions. The following three types of bit manipulation addressing modes can be used according to the data memory address to be used: (a) Specific address bit direct addressing (fmem. bit). A, @HL This addressing mode enables, peripheral hardware that frequently uses bit manipulation, such as input/output ports and interrupt flags, to be operated at any time independently of the memory bank setting. Thus, the addressing mode is applicable to data memory addresses FF0H-FFFH (where input/output ports are mapped) and FB0H-FBFH (where hardware related to interrupts is mapped). For the hardware of the two data memory areas, bit manipulation can be performed in direct addressing at any time as desired regardless of how MBS and MBE are set. Example 1: To test the timer 0 interrupt request flag (IRQT0); if the request flag is set, clear the flag and reset P63. Example 2: To reset P53 if both P30 and P41 are set to 1. | (i) | SET1<br>AND1<br>AND1<br>SKT<br>BR<br>CLR1 | CY<br>CY, PORT3.0<br>CY, PORT4.1<br>CY<br>SETP<br>PORT5.3 | ; | CY ← 1<br>CY P3.0<br>CY P4.1<br>CY = 1 ?<br>P53 ← 1 | |-------|-------------------------------------------|-----------------------------------------------------------|---|-----------------------------------------------------| | SETP: | SET1 P | ORT5.3 | ; | P53 <del>←</del> 1 | | (ii) | SKT<br>BR | PORT3.0<br>SETP | ; | P30 = 1 ? | | | SKT<br>BR | PORT4.1<br>SETP | ; | P41 = 1 ? | | | CLR1 | PORT5.3 | ; | P53 <del>←</del> 0 | | STEP: | SET1 | PORT5.3 | ; | P53 <del>←</del> 1 | (b) Specific address bit register indirect addressing (pmem. @L). This addressing mode indirectly specifies each bit of peripheral hardware, such as an input / output port, by using the L register for successive operation. The addressing mode is applicable to data memory addresses FC0H-FFFH. The addressing mode directly specifies the high-order 10 bits of a 12-bit data memory address in the pmem operand and rine addressing mode directly specifies the night-order 10 bits of a 12-bit data memory address in the primem operand and indirectly specifies the low-order 2-bit data memory address part and the bit address by using the L register. Thus, 16 bits (four ports) can be manipulated (operated) successively by L register specification. The address mode also enable bit manipulation to be performed at any time independently of how MBE and MBS are set. Example: To output a pulse to each bit of ports 4 to 7 in order. (c) Special 1-bit direct addressing (@H + mem. bit) This addressing mode enables bit manipulation to be performed on any bit in all of the data memory space. The addressing mode indirectly specifies the high-order four bits of data memory address of the memory bank specified by MB = MBE MBS by using the H register and directly specifies the low-order 4-bit data memory address part and the bit address in the operands. It enable various types of bit manipulation to be performed on any bit in all of the data memory space. Example: To reset address 32H bit 2 (FLAG3) if both address 30H bit 3 (FLAG1) and address 31H bit 0 (FLAG2) are set to 0 or 1. ``` FLAG1 EQU 30H.3 FLAG2 EQU 31H.0 FLAG3 EQU 32H.2 SEL MB0 MOV H, #FLAG1 SHR 6 CLR1 OR1 CY. @H + FLAG1 CY-FLAG1 XOR1 CY, @H + FLAG2 CY ← CY-FLAG2 SET1 @H + FLAG3 CY = 1 ? SKT CY FLAG<sup>→</sup> 30 CLR1 @H + FLAG3 ``` ## (7) Stack addressing The stack addressing mode is used for register save and restore during interrupt service or subroutine processing. The processing mode specifies an address by using the 8-bit stack pointer (data memory bank 0). The addressing mode can also be used for register save and restore by executing the PUSH and POP instructions. Example 1: To save and restore register in subroutine processing. Example 2: To transfer the HL register pair contents to the DE register pair. PUSH HL POP DE ; DE← HL Example 3: To branch to the address indicated by [XABC] register. PUSH BC PUSH XA RET : Branch to XABC address #### 3.2 Memory Mapped I / O The $\mu$ PD75328 adopts memory mapped I/O where peripheral hardware such as input/ports and timers is allocated to addresses F80H-FFFH of the data memory space as shown in Fig. 3.1–2. Thus, peripheral hardware is controlled entirely by memory operation instructions rather than special instructions. (To easily understand programs, some hardware control mnemonics are provided.) Table 3.2-1 lists the addressing modes that can be used to operate peripheral hardware. Memory bank 1 is specified to operate the display data memory mapped in addresses 1ECH-1FFH. Table 3.2-1 Applicable Addressing Modes during Peripheral Hardware Operation | | Applicable addressing mode | Applicable hardware | | |---------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--| | - | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem. bit). | All hardware where bit manipulation can be performed. | | | Bit<br>manipulation | Direct addressing regardless of how MBE and MBS are set. (specification in fmem. bit) | ISTO, MBE<br>IExxx, IRQxxx, PORTn.x | | | | Indirect addressing regardless of how MBE and MBS are set. (specification in pmem. @L) | BSBn.x<br>PORTn.x | | | 4-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem). | All hardware where 4-bit manipulation can be performed. | | | manipulation | With (MBE=1 and MBS=15), register indirect addressing (specification in @HL). | | | | 8-bit | With MBE=0 or (MBE=1 and MBS=15), direct addressing (specification in mem), mem must be an even address. | All hardware where 8-bit manipulation can | | | manipulation | With MBE=1 and MBS=15, register indirect addressing (specification in @HL; the L register must contain an even number. | be performed. | | Example: CLR1 MBE MBE = 0SET<sub>1</sub> TM0.3 Timer 0 starts. ΕI IF0 INT0 is enabled. DI IE1 INT1 is disabled. SKTCLR IRQ2 INT2 request flag is tested and cleared. SET PORT4. @L ; Port 4 is set. Figs. 3.2-1 to 3.2-3 shows the μPD75328 I/O map. The columns in the figures mean: · Abbreviation: Name indicating internal hardware address. It can be entered in the instruction operand field. #### R/W Indicates whether the hardware device can be read or written. - R/W : Read and write are enabled. - R : Read only is enabled.W : Write only is enabled. - · Number of bits that can be manipulated: Indicates the number of bits that can be processed when the hardware device is operated. - O: Bit manipulation is enabled in 1-4, 4-, or 8-bit units as specified in the column. - Δ: Only some bits can be manipulated. See Remarks for the bits that can be manipulated. - -: Bit manipulation cannot be performed in 1-, 4-, or 8-bit units as specified in the column. # · Bit manipulation addressing: Indicates the applicable bit manipulation addressing for performing bit manipulation on the hardware device. | Address | Hardware name (abbreviation) | R/W | 1 | ber of bit<br>e manipi | | Bit manipulation | Remarks | |---------|-------------------------------------------|--------|------------|------------------------|--------------|------------------|--------------------------------------------------| | Address | b3 b2 b1 b0 | F1/ VV | One<br>bit | Four<br>bit | Eight<br>bit | addressing | Hemarks | | F80H | Stack pointer (SP) | R/W | | - | 0 | | Bit 0 is fixed to 0. | | F85H | Basic interval timer mode register (BTM) | w | Δ | 0 | - | mem. bit | Bit manipulation can be performed only on bit 3. | | F86 H | Basic interval timer (BT) | R | - | - | 0 | | | | F8CH | Display mode register (LCDM) | w | Δ | | 0 | mem. bit | Bit manipulation can be performed only on bit 3. | | | | | | | | | | | F8EH | Display control register (LCDC) | W | | 0 | | | | | F98H | Watch mode register (WM) | R/W | Δ | _ | 0 | O mem. bit | Bit test can be made only on bit 3. | | | | | - | - | | | | | FA0H | Timer/event counter 0 mode register (TM0) | w | Δ | - | 0 | mem. bit | Bit manipulation can be performed only on bit 3. | | | | | - | | | 4 | | | FA2H | TOE0 (Note) | w | 0 | - | - | mem. bit | | | FA4H | Timer/event counter 0 count register (T0) | R | - | | 0 | - | | | FA6H | Timer/event counter 0 modulo | | _ | _ | | | | | | register (TMOD0) | w | _ | _ | 0 | | | | FB0H | 0 ISTO MBE 0 | R/W | 0 | 0 | 0 | | | | | Program status word (PSW) | R | - | - | | | | | FB2H | (IME) | , – | - | - | - | fmem. bit | El and DI instructions are used | | FB3H | Processor clock control register (PCC) | | - | 0 | | | | | FB4H | INT0 mode register (IM0) | W | - | 0 | | | Bit 2 is fixed to 0. | | FB5H | INT1 mode register (IM1) | W | - | 0 | - | | Bit 3 to 1 are fixed to 0. | | FB6H | INT2 mode register (IM2) | W | - | 0 | | | Bits 3 and 2 are fixed to 0. | | FB7H | System clock control register (SCC) | W | 0 | _ | _ | | only buts 3 and 0 can be bit manipulated | Note: TOE0 = timer / event counter 0 output enable flag (W) (to be continued) Figure 3.2-1 μPD75328 I/O Map | Address | Hardware name (abbreviation) | | | R/W | Number of bits that can be manipulated | | | Bit manipulation | Remarks | | |---------|--------------------------------------------------------|------------|------------|--------|----------------------------------------|------------|-------------|------------------|-------------------------------------------|----------| | Address | b3 | b2 | b1 | b0 | H/VV | One<br>bit | Four<br>bit | Eight<br>bit | addressing | nemarks | | FB8H | IE4 | IRQ4 | IEBT | IRQBT | R/W | 0 | 0 | | | | | FBAH | | | IEW | IRQW | R/W | 0 | 0 | - | | | | FBCH | | | IET0 | IRQT0 | R/W | 0 | 0 | | | | | FBDH | | | IECSI | IRQCSI | R/W | 0 | 0 | | fmem. bit | | | FBEH | IE1 | IRQ1 | IE0 | IRQ0 | R/W | 0 | 0 | | | | | FBFH | | | IE2 | IRQ2 | R/W | 0 | 0 | - 1 | | | | FC0H | Bit sequ | ential buf | fer 0 (BSE | 30) | R/W | 0 | 0 | _ | | | | FC1H | Bit sequ | ential buf | fer 1 (BSE | 31) | R/W | 0 | 0 | 0 | mem. bit | | | FC2H | Bit sequential buffer 2 (BSB2) | | | | R/W | 0 | 0 | | pmem @L | | | FC3H | Bit sequ | ential buf | fer 3 (BSE | 33) | R/W | 0 | 0 | 0 | | | | FD0H | Clock or | utput mod | e register | (CLOM) | w | _ | 0 | _ | | - | | FD8H | SOC EOC | | | R/W | Δ | _ | | mem,bit | EOC R, SOC W | | | | A/D convert mode register (ADM) | | | w | _ | - | 0 | | · · · · · · · · · · · · · · · · · · · | | | FDAH | SA register (SA) | | | | R | | - | 0 | | | | FDCH | Pull-up resistor specification register group A (POGA) | | | | w | _ | - | 0 | | | | FDEH | Pull-up resistor specification register group B (POGB) | | | w | - | - | 0 | 12 - 1 | | | | FE0H | Serial operation mode register | | | w | _ | _ | | | | | | | (CSIM) CSIE COI WUP | | | R/W | 0 | 0 | 0 | mem. bit | | | | FE2H | CMDD | RELD | CMDT | RELT | l | | | | | | | FEZH | SBI control register (SBIC) | | | R/W | 0 | | _ | mem. bit | Only bit manipulation can be performed on | | | | BSYE | ACKD | ACKE | ACKT | | | | | | any bit. | | FE4H | Serial I/O shift register (SIO) | | | | R/W | - | | ,o | | | | FE6H | Slave address register (SVA) | | | | w | - | _ | 0 | | | | FE8H | РМЗЗ | PM32 | PM31 | PM30 | | | | | | | | | Port mode register group A (PMGA) | | | w | _ | _ | 0 | | | | | | PM63 | PM62 | PM61 | PM60 | 1 | | | | | | | FECH | - | PM2 | - | - | | | | | | | | | Port mode register group B (PMGB) | | | | w | - | - | 0 | | | | | PM7 0 PM5 PM4 | | | | | | | | | | Remarks: 1. IExxx is an interrupt enable flag. (to be continued) <sup>2.</sup> IRQxxx is an interrupt request flag.3. IME is an interrupt master flag. | Address | Hardy | R/W | Number of bits that can be manipulated | | | Bit manipulation | Remarks | | | | | |---------|-----------------------------------|----------------|----------------------------------------|---------|-------|------------------------|---------|------------|-----------|-----|--| | Address | b3 | b2 | b1 | b0 | 17.44 | One Four Eight for bit | | addressing | Homano | | | | FEEH | | | | (D1400) | | - | - | | | : ' | | | | Port mode register group C (PMGC) | | | | w | _ | _ | 0 | | | | | FF0H | Port 0 | | (PC | ORT 0) | R | 0 | 0 | | | : . | | | FF1H | Port 1 | | (PC | ORT 1) | R | 0 | 0 | | | 1 | | | FF2H | Port 2 | | (PC | ORT 2) | R/W | 0 | 0 | _ | | | | | FF3H | Port 3 | | (PC | ORT 3) | R/W | 0 | 0 | | fmem. bit | | | | FF4H | Port 4 | ort 4 (PORT 4) | | | R/W | 0 | 0 | 0 | pmem. @L | | | | FF5H | Port 5 | ort 5 (PORT 5) | | | R/W | 0 | 0 | | | | | | FF6H | KR3 | KR2 | KR1 | KR0 | R/W | 0 | 0 | | | | | | (Note) | Port 6 | ort 6 (PORT 6) | | | IT/VV | U | U | 0 | | | | | FF7H | KR7 | KR6 | KR5 | KR4 | R/W | 0 | 0 | | | | | | (Note) | Port 7 | rt 7 (PORT 7) | | | 1000 | | | | | | | | FF8H | Port 8 | | (PC | ORT8) | R/W | 0 | 0 | - | | | | Note: KR0-KR7 can only be read. When 4bit parallel is input, specified at PORT6 or PORT7. Figure 3.2-1 μPD75328 I/O Map (con`t) ## **4 INTERNAL CPU FUNCTIONS** ## 4.1 Program Counter (PC) - 13-Bit (μPD75328) The program counter is binary counter which holds program memory address information. The $\mu$ PD75328 is configured of 13-bit (See Fig. 4.4–1). μPD75328 format | PC12 PC11 PC10 | 1 000 | 1 000 | 007 | 000 | 200 | DO 4 | 000 | 000 | 004 | 000 | |-----------------------|--------|-------|------|-----|-------|------|-------|-------|------|-------| | _ 1 PC121 PC11 1 PC10 | I P(39 | I PCX | IPC/ | PUb | I PCS | PC4 | 1 PG3 | 1 PC2 | וטאו | 1 200 | | 1, 0,21, 0,,1, 0,0 | 1 | | | | | | | | | | Figure 4.1-1 Program Counter Format Each time one instruction is executed, normally the program counter is automatically incremented according to the number of the bytes in the instruction. When a branch instruction (BR or BRCB) is executed, the register pair contents or immediate data indicating the branch destination address is loaded into all or some of the PC bits. When a subroutine call instruction (CALL or CALLF) is executed or a vectored interrupt occurs, the current PC contents (return address already incremented to fetch the next instruction) are saved in stack memory (data memory indicated by the stack pointer), then the jump destination address is loaded. When a return instruction (RET, RETS, or RETI) is executed, the stack memory contents are loaded into the PC. When the RESET signal is generated, the program memory contents are loaded into the program counter for initialization, as follows: (Program can be started at any desired address.) μPD75328: PC12-PC8 low-order five bits at address 0000H PC7 -PC0 ← eight bits at address 0001H ## 4.2 Program Memory (ROM) - 8064 Words x Eight bit (μPD75328) The program memory stores programs, interrupt vector table, GETI instruction look up table, and data such as table data. The program memory of the $\mu$ PD75328, is mask programmable ROM. Fig. 4.2-1 to 4.2-5 show the program memory map. The program memory is addressed by using the program counter. Table data can also be referenced by using the table reference instruction (MOVT). The address range for branching by a branch or subroutine call instruction is as shown in Fig. 4.2–1. When a relative branch instruction (BR \$addr) is used, a branch can be made to [PC contents – 15 to –1, +2 to + 16] address independently of block. The program memory addresses are shown below. • 0000H-1F7FH : μPD75328 The following addresses are assigned for special purpose: (All the area except address 0000H to 0001H Note 1 can be used as normal program memory area.). ## 0000H – 0001H $Vector address \ table \ in \ which \ the \ program \ start \ address \ and \ MBE \ setup \ value \ are \ entered \ when \ the \ system \ is \ reset. \ (Reset \ start \ can \ be \ made \ at \ any \ desired \ address.)$ ## • 0002H - 000BH Vector address table in which the program start address and MBE setup value are entered for each vectored interrupt. (Interrupt service can be started at any desired address.) - 0020H 007FH Table area referenced by GETI (Note 2). - Note: 1. Their addresses are used in the µPD75328. - The GETI instruction is used to convert any 2- or 3-byte instruction or any two 1-byte instructions into a 1-byte instruction. The number of program bytes can be reduced. Figure 4.2-1 Program Memory Map (µPD75328) ## 4.3 Data Memory (RAM) - 512 Words x Four Bits The data memory is a general purpose static RAM consisting of 512 words x four bits. Since a static RAM stores data during process, subroutine, or interrupt execution, it can also hold data when CPU operation is stopped in the standby mode; it is useful in that the memory contents can be held with battery power for hours. Fig. 4.3–1 shows a μPD75328 data memory map. The data memory adopts the bank configuration, consisting of banks 0 and 1 (each 256 words x four bits). Peripheral hardware is mapped in the memory bank 15 area. A memory bank is selected by setting the 4-bit memory bank selection register (MBS = 0, 1, or 15) when bank specification is enable by setting the memory bank enable flag (MBE) to 1 (MBE = 1). When bank specification is disabled (MBS = 0), memory bank 0 or 15 is automatically selected according to the current addressing mode. Each bank is addressed by using 8-bit immediate data, a register pair, etc. Although a data memory word consists of four bits, the data memory can be handled in 1-, 4-, or 8-bit units by using various addressing modes. See 3.1 for details of memory bank selection and addressing modes. Specific areas of the data memory are also used for general purpose registers (bank 0; 000H – 0007H), stack memory (bank 0; 000H – 0FFH) and display data memory (bank 1; 1ECH – 1FFH). Data memory does not exist in bank 15. Peripheral hardware and various registers are mapped. Do not access addresses or bits to which no registers are allocated. For the use of the specific areas of data memory, see the following: - · 4.4 for the general purpose register area - · 4.6 for the stack memory area - · 5.7.5 for the display data memory - · CHAPTER 5 for the peripheral hardware Figure 4.3-1 Data Memory Map The data memory is undefined when the system is reset during normal operation mode (not standby), because of possible memory access at the time of reset. Be sure to initialize it too (clear RAM), normally at the program start. Figure 4.3–2 Display Data Memory Configuration The display data memory is handled in 1- or 4-bit units. Caution: The display data memory cannot be handled in 8-bit units. Example: To clear 1ECH-1FFH display data memory. SET1 MBE SEL MB1 MOV HL, #0ECH MOV A, #00H LOOP: MOV Display data memory is cleared in4-bit units at a time @HL, A **INCS** BR LOOP INCS BB LOOP ## 4.4 General Purpose Registers - Eight x Four Bits The general purpose registers are eight 4-bit registers (B, C, D, E, H, L, X, and A) mapped in specific addresses of the data memory. Every general purpose register is handled in 4-bit units; register pairs BC, DE, HL, and XA are also used for 8-bit manipulation. In addition to DE and HL, registers D and L are also paired (DL), and the three register pairs can be used for data pointers. The general purpose register area can be addressed and accessed as normal RAM regardless of whether or not it is used for registers. | X<br>01H | А 00Н | |----------|-------| | н | L | | | 02H | | D | E | | 05H | 04H | | B<br>07H | С 06Н | Figure 4.4-1 General Purpose Register Configuration (When 4-bit processing is performed) | XA | | |----|-----| | | 00H | | HL | | | | 02H | | DE | | | | 04H | | ВС | | | | 06H | Figure 4.4–2 General Purpose Register Configuration (When 8-bit processing is performed) Figure 4.4-3 Register Pair Configuration #### 4.5 Accumulator The μPD75328 uses the A register and XA register pair for accumulators. The A register is used as the main register during execution of 4-bit data processing instructions; the XA register pair is used as the main register pair during execution of 8-bit data processing instructions. The carry flag (CY) is used for a bit accumulator during execution of bit manipulation instructions. Figure 4.5-1 Accumulator ## 4.6 Stack Pointer (SP) - Eight Bits The $\mu PD75328$ uses general purpose RAM for stack memory (LIFO). The stack pointer (SP) is an 8-bit register which holds top address information of the stack area. The stack area addresses are 000H-0FFH of memory bank 0 regardless of how MBE and MBS are set. SP is decremented before data is saved in the stack memory (write operation); it is incremented after data is restored from the stack memory (read operation). Figs. 4.6-2 to 4.6-4 shows data saved in and restored from the stack memory when stack operations are performed. An initial value is set in SP by using an 8-bit memory operation instruction to determine the stack area to be used. The SP contents can also be read. SP0 is always set to 0. It is recommended that the initial value of SP should be set to 00H so that the stack area be used is starting at the most significant address of data memory bank 0 (0FFH). When the RESET signal is generated, the SP contents become undefined. Be sure to initialize SP to the desired value at the start of the program. Example: To initialize SP. Figure 4.6-1 Stack Pointer Configuration ## (a) Data Saved in Stack Memory ## (b) Data Restored from Stack Memory Figure 4.6–3 Data Saved / Restored in Stack Operation $\mu\text{PD75328}$ # 4.7 Program Status Word (PSW) - Eight Bits The program status word (PSW) consists of flags closely related to processor operation. PSW is mapped in data memory addresses FB0H and FB1H. Two bits of address FB0H can be operated by using a memory operation instruction. Figure 4.7-1 Program Status Word Configuration Table 4.7-1 PSW Flags Saved and Restored when Stack Operation is Performed | | | Saved or restored flag | | |---------|------------------------------------------|---------------------------|--| | Save | During CALL, CALLF instruction execution | MBE is saved | | | Jave | During hardware interrupt | All PSW bits are saved | | | Restore | During RET, RETS instruction execution | MBE is restored | | | Nestore | During RETI instruction execution | All PSW bits are restored | | ## (1) Carry flag (CY) The carry is a 1-bit flag that shows the occurence of overflow or underflow during execution of an instruction involving carry (ADDC or SUBC). The carry flag also serves as a bit accumulator. Boolean algebra operation is performed between the bit accumulator and data memory specified by a bit address. The result can be stored in the bit accumulator. The carry flag is operated by using dedicated instructions independently of other PSW bits. When the RESET signal is generated, the carry flag becomes undefined. Table 4.7-2 Carry Flag Operation Instructions | | Instructions (mnemonic) | Carry flag processing | |------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------| | Instructions dedicated to carry flag operation | SET1 CY<br>CLR1 CY<br>NOT1 CY<br>SKT CY | CY is set to 1<br>CY is cleared<br>CY is inverted<br>Skip if CY is set to 1 | | Bit Boolean instructions | AND1 CY, mem*.bit OR1 CY, mem*.bit XOR1 CY, mem*.bit | The specified bit and CY are ANDed, ORed, or XORed together | | Interrupt service | During interrupt execution | CY is saved in stack<br>memory in parallel with<br>other PSW bits (eight bits) | | interrupt service | RETI | CY is restored from stack<br>memory in parallel with<br>other PSW bits | Remarks: mem\*.bit indicates any of the following three bit 3 manipulation addressing modes - · fmem.bit - · pmem.@L - · @H + mem.bit Example: To AND bit 3 of address 3H and P33 together and set the result in CY. SET1 CY ; CY<del> 1</del> CLR1 MBE ; Or SEL MB0 SKT 3FH. 3 ; Skip if bit 3 of address 3FH is set to 1. CLR1 CY ; $CY \leftarrow 0$ AND1 CY, PORT3.3 ; $CY \leftarrow CY \land P33$ 71101 01,101110.0 , 01 017 1100 (2) Skip flags (SK2, SK1, and SK0) The skip flags store the skip state and are automatically set or reset when the CPU executes instructions. The user cannot directly use the flags as operands. (3) Interrupt status flag (IST0) The interrupt status flag stores the current status of processing being performed. (For details, see Table 6.3-2.) Table 4.7-3 Interrupt Status Flag Indication Contents | IST0 | Status of processing<br>being performed | Processing contents and interrupt control | |------|-----------------------------------------|---------------------------------------------------------------------------| | 0 | Status 0 | During normal program processing.<br>Every interrupt can be acknowledged. | | 1 | Status 1 | During interrupt processing. No interrupt must be acknowledged. | If an interrupt is acknowledged, the IST0 contents are saved in stack memory as a PSW bit, then automatically IST0 is set to 1. When an RETI instruction is executed, IST0 is set to 0. The interrupt status flag can be operated by using a memory operation instruction. The current status of processing can also be changed under program control. Caution: Before operating the flag, be sure to execute a DI instruction to disable interrupts. After operating the flag, execute an EI instruction to enable interrupts. (4) Memory bank enable flag (MBE) The memory bank enable flag is a 1-bit flag used to specify the address information generation mode of the high-order four bits of a 12-bit data memory address. MBS can be set or reset at any time by using a bit manipulation instruction regardless of memory bank setting. Example: SET1 MBE ; MBE ← 1 CLR1 MBE ; MBE ← 0 When MBE is set to 1, the data memory address space is exceeded and all the data memory space can be addressed. When MBE is reset to 0, the data memory address space is fixed regardless of how MBS is set. (see Fig. 3.1-2.) When the RESET signal is generated, the contents of program memory address 0 bit 7 are set and MBE is initialized automatically. When vectored interrupt service is made, bit 7 of the corresponding vector address table is set and the MBE state during interrupt service is set automatically. During interrupt service, normally MBE is set to 0 and the general purpose RAM of memory bank 0 is used. #### 4.8 Bank Selection Register (BS) The memory bank selection register (MBS) for selecting a memory bank is mapped in the bank selection register (BS). The low-order four bits of BS are fixed to 0 MBS is set by using the SEL MBn instructions. BS can be saved in and restored from the stack area in 8-bit units by using PUSH BS instructions. Figure 4.8-1 Bank Selection Register Configuration ## (1) Memory bank selection register (MBS) The memory bank selection register (MBS), consisting of four bits, stores high-order 4-bit address information of a 12-bit data memory address. The memory bank to be accessed is specified according to the register contents. However, the $\mu$ PD75328 allows the user to select bank 0, bank 1, or bank 15 only. MBS is set by using the SEL MBn instruction (where n is 0, 1, or 15). The address range applied according to how MBE and MBS are set is as shown in Fig. 3.1-2. When the RESET signal is generated, MBS is initialized to 0. ## **5 PERIPHERAL HARDWARE FUNCTIONS** # 5.1 Digital Input / Output Ports The µPD75328 adopts memory mapped I/O. All input / output ports are mapped in the data memory space. Bit 0 in addresses 1F8H-1FFH is used for output latches for bit port outputs BP0-BP7. For BP0–BP7, bit port output can be switched in 4-bit units by using display mode register (LCDM) bits 6 and 7. (See Fig. 5.7–2) 1F8H–1FFH bits not used for bit port output latches can be used for display memory or general purpose RAM. These addresses can be handled in 1- or 4-bit units. These addresses cannot be handled in 8-bit unit. | Address | 3 | 2 | 1 | 0 | | |---------|-----|-----|---------------|-----|--------| | FF0H | P03 | P02 | P01 | P00 | PORT 0 | | FF1H | P13 | P12 | P11 | P10 | PORT 1 | | FF2H | P23 | P22 | P21 | P20 | PORT 2 | | FF3H | P33 | P32 | P31 | P30 | PORT 3 | | FF4H | P43 | P42 | P41 | P40 | PORT 4 | | FF5H | P53 | P52 | P51 | P50 | PORT 5 | | FF6H | P63 | P62 | P61 | P60 | PORT 6 | | FF7H | P73 | P72 | P71 | P70 | PORT 7 | | FF8H | P83 | P82 | P81 | P80 | PORT 8 | | 1F8H | | _ | - ** | BP0 | | | 1F9H | _ | | - | BP1 | | | 1FAH | - | i – | - | BP2 | | | 1FBH | - | - | 1 - 1 | BP3 | | | 1FCH | _ | - | _ | BP4 | | | 1FDH | _ | _ | 1 - 1 - 1 - 1 | BP5 | | | 1FEH | _ | | - | BP6 | | | 1FFH | - | - | - 1 | BP7 | | Remarks: The part of - bits can be used for general purpose RAM ## Figure 5.1-1 Data Memory Addresses of Digital Ports Table 5.1–2 lists the input / output port operation instructions. In addition to 4-bit input / output, 8-bit input / output and bit manipulation can be performed for PORT 4 to PORT 7 and very diverse control can be performed. BP0–BP7 are 1-bit output ports. Example: To test the P13 state and output value to ports 4 and 5 depending on the result. SKT PORT1.3 ; Skip if port 1 bit 3 is set to 1 MOV XA, #18H ; XA ← 18H String effect MOV XA, #14H ; XA ← 14H String effect SEL MB15 ; Or CLR1 MBE OUT PORT4, XA : Ports 5,4 ← XA Example: SET1 PORT 4. @L ; The port 4-7 bit specified by using the L register is set to 1. Example: To output 1 to BP0. SET1 MBE SEL MB1 ; Memory bank 1 is selected SET1 BP0 ; BP0 1 5.1.1 Types, features, and configurations of digital input / output ports Table 5.1-1 lists the digital input / output ports. Figs. 5.1-1 to 5.1-5 shows the port configurations. Table 5.1-1 Types and Features of Digital Ports | Port (abbreviation) | Function | Operation and features | Remarks | | |---------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--| | PORT 0 | 4-bit input | Can always be read or tested regardless of the operation mode. | Pins also used for INT4, SCK<br>SO/SB0, SI/SB1. Pins also | | | PORT 1 | | or the operation mode. | used for INT0-2 and TI0. | | | PORT 3(Note 1) | | Can be placed in input or output mode in 1-bit units. | Pins also used for LCDCL SYNC and MD0-MD3, (Note 2) | | | PORT 6 | . • | in r-bit units. | Pins also used for KR0-KR3. | | | PORT 2 | 4-bit input / output | Can be placed in input or ouput mode | Port 2 pins are also used for PTO0, PCL, and BUZ. | | | PORT 7 | | in 4-bit units. Ports 6 and 7 can be paired for data input / output in 8-bit units | Pins also used for KR4-KR7. | | | PORT 8 | | pariod for data input? output in o bit drine | | | | PORT 4(Note 1) | 4-bit input / output<br>(N-channel open | Can be placed in input or output mode in 4-bit units. Ports 4 and 5 can be paired | Internal pull-up resistor can be specified in 1-bit units by using | | | PORT 5(Note 1) | drain 10 Volts) | for data input / output in 8-bit units. | mask option. | | | BP0-BP7 | 1-bit output | Data is output in 1-bit units. The BPO-BP7 pins are also used as output pins (S24-S31) for the LCD driving segment signal. BPO-BP7 and S24-S31 can be changed by using software. | The capacity of drive is very small. Used for CMOS load drive. | | Note 1: An LED can be driven directly. Note 2: PORT 3 is also used for MD0-MD3 pin only in $\mu$ PD75P328. The P10 pin is also used for an external vectored interrupt input pin (input with a noise removal circuit). (For details, see 6.3.) The BPO-BP7 pins are also used for driving LCD segment signal output pins (S24-S31);they are changed in 4- or 8-pin units by using display mode register (LCDM) bits 6 and 7. BPO-BP7 are 1-bit output ports. Data for bit 0 in each of the display data memory addresses 1F8H-1FFH is output. (See 5.7.5.) When the RESET signal is generated, port 2-port 7 output latches are cleared, the output buffers are turned off, and input mode is entered. Figure 5.1-2 Configuration of Ports 0 or 1 Figure 5.1–3 Configuration of port 3n or 6n (n = 0–3) Figure 5.1-4 Configuration of Port 2, 7 or 8 Figure 5.1-5 Configuration of Port 4 or 5 ## 5.1.2 Input / output mode setting CLR1 MBE The input or output mode of each input/output ports is set by using the port mode register as shown in Fig. 5.1–6. Each bit of ports 3 and 6 can be placed in input or output mode individually by using port mode register group A (PMGA). Each of ports 2, 4, 5, and 7 (four bits each) is placed in input or output mode individually by using port mode register group B (PMGB). Port 8 (four bits) is placed in input or output mode individually by using port mode register group C (PMGC). Each port serves as an input port when the corresponding port mode register bit is set to = 0 and serves as an output port when set to 1. Since the output latch contents are applied to the output pins at the same time the output mode is selected by setting the port mode register, the output latch contents must previously be rewitten to the required value before the output mode is set. Port mode register groups A and B are set by using 8-bit memory operation instructions : Or SEL MB15 When the RESET signal is generated, all bits of the port mode registers are cleared; thus the output buffers are turned off, and all ports are placed in input mode. Example: To use P30, P31, P62, and P63 for input pins and P32, P33, P60, and P61 for output pins. | MOV<br>MOV | XA, #3C<br>PMGA, ) | Н | JI SEL IMB | | | | | | | | | | | |------------|--------------------|------------|---------------|--------------|----------------|---------|------|------|--------|--|--|--|--| | | | | Po | ort mode re | gister group | Α | | | | | | | | | Address | 7 | 6 | 6 5 4 3 2 1 0 | | | | | | | | | | | | FE8H | PM63 | PM62 | PM61 | PM60 | PM33 | PM32 | PM31 | PM30 | PMGA | | | | | | | PM3n<br>PM6n | P3n, P6n | pin input / c | output speci | fication (n = | : 0-3) | | | | | | | | | | 0 | Input mod | le (output b | uffer off) | | | | | | | | | | | PMGA | 1 | Output mo | ode (output | buffer on) | | | | | | | | | | | | | | Po | ort mode re | gister group | В | | | | | | | | | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | | | | | | FECH | PM7 | | PM5 | PM4 | - | PM2 | _ | - | PMGC | | | | | | | PMn | Port n inp | ut / output s | pecification | n (n = 2, 4, 5 | , or 7) | | | | | | | | | | 0 | Input mod | le (output b | uffer off) | | | | | | | | | | | | 1 | Output mo | ode (output | buffer on) | - | | | | | | | | | | | | | Po | ort mode re | gister group | С | | | | | | | | | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | | | | | | FEEH | _ | | _ | - | - | _ | - | PM8 | PMGB | | | | | | | PM8 | Port 8 inp | ut / output s | pecification | l | | | | | | | | | | | 0 | Input mod | le (output b | uffer off) | | 1 - | | | | | | | | | | 1 | Output mo | ode (output | buffer on) | | | | | | | | | | Figure 5.1-6 Port Mode Register Formats -: May be 0 or 1. 5.1.3 Digital input / output port operation instructions operation and their application ranges. Since all input / output ports incorporated in the µPD75328 are mapped in the data memory space, all the data memory operation instructions are applicable. Table 5.1-2 lists the data memory operation instructions particulary useful for input / output pin #### (1) Bit operation instructions The specific address bit direct addressing (fmem. bit) and specific address bit register indirect addressing (pmem. @L) modes are applicable to digital input / output ports PORT 0-PORT 7. The port bits can be operated at any time as desired regardless of how MBE and MBS are set. Example: To OR P50 and P41 together and output the result to P61. AND1 CY, PORT5.0 ; CY ← CY ↑ P50 OR1 CY, PORT4.1 : CY ← CY ∨ P41 SKT CY BR CLRP SET1 PORT6.1 ; P61 ← 1 ## (2) 4-bit operation instructions In addition to the IN and OUT instructions, all 4-bit memory operation instructions such as MOV, XCH, ADDS, and INCS can be used. However, memory bank 15 must have been selected before executing an instruction. Example 1: To output the accumulator contents to port 3. SEL MB15 ; Or CLR1 MBE OUT PORT3, A Example 2: To add the accumulator value to the data output to port 5 and output the result. SET1 MBE SEL MB15 MOV HL, #PORT5 ADDS A, @HL : A← A+PORT5 NOP MOV @HL, A ; PORT5 ← A Example 3: To test whether or not data in port 4 is greater than the accumulator value. SET1 MBE SEL MB15 MOV HL, #PORT4 SUBS A, @HL ; A<PORT4 BR NO ; NO ; YES #### (3) 8-bit operation instructions In addition to the IN and OUT instructions, the MOV, XCH and SKE instructions can be used for ports 4 and 5 where 8-bit operation (manipulation) can be performed. As with the 4-bit operation instructions, memory bank 15 must have been selected before executing the instruction. Example: To output data in the BC register pair to the output ports specified by the 8-bit data input from ports 4 and 5. SET 1 MBE SEL MB15 IN XA, PORT 4; XA → ports 5 and 4 MOV HL, XA ; HL — XA MOV XA, BC ; XA — BC MOV @HL, XA : Port (L) — XA Table 5.1-2 Input / Output Port Pin Operation Instruction List | PORT<br>Instruction | PORT<br>0 | PORT<br>1 | PORT<br>2 | PORT<br>3 | PORT<br>4 | PORT<br>5 | PORT<br>6 | PORT<br>7 | PORT<br>8 | BIT•PORT<br>0–7 | |--------------------------------|-----------|-----------|-----------|-----------|-----------|---------------------|-----------------------------------|------------------------------------|-----------|----------------------------------------------------| | IN A, PORTn<br>(Note 1) | 1.13.4.1 | | | | 0 | | | | | <u>-</u> | | IN XA, PORTn<br>(Note 1) | _ | - | _ | _ | C | ) | ( | ) in a | - | _ | | OUT PORTn. A<br>(Note 1) | - | 1 | | | | 0 | | | | MOV mem, A<br>(Notes 3 and 4) | | OUT PORTn. XA<br>(Note 1) | - | - , | - | - | ( | 0 | . ( | ) 1 | - L | | | SET1 PORTn. bit | - | _ | | | | 0 | | | | SET1 BPn<br>(Note 3) | | SET1 PORTn. @L<br>(Note 2) | - | 1 | | | | 0 | | 100 | | 12 1 <u>21</u> 1 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | | CLR1 PORTn. bit | - | 1 | | | | 0 | | | | CLR1 BPn<br>(Note 3) | | CLR1 PORTn. @L<br>(Note 2) | - | - | | 0 | | | | _ | | | | SKT PORTn. bit | | 0 | | | | SKT BPn<br>(Note 3) | | | | | | SKT PORTn. @L<br>(Note 2) | | | | | 0 | | | | | - | | SKF PORTn. bit | | | | | 0 | | | | | SKF BPn<br>(Note 3) | | SKF PORTn. @L<br>(Note 2) | | | | | 0 | | | | | - | | AND1 CY, PORTn. bit | | | | | 0 | | 1 | | | AND1 CY, @H+BPn<br>(Notes 3 and 5) | | AND1 CY, PORTn. @L<br>(Note 2) | o | | | | | | - | | | | | OR1 CY, PORTn. bit | | 0 | | | | | OR1 CY, @H+BPn<br>(Notes 3 and 5) | | | | | OR1 CY, PORTn. @L<br>(Note 2) | | o | | | | | | - | | | | XOR1 CY, PORTn. bit | | 0 | | | | | | XOR1 CY, @H+BPn<br>(Notes 3 and 5) | | | | XOR1 CY, PORTn. @L<br>(Note 2) | | | | 0 | | | | | | - | Note 1: MBE = 0 or (MBE = 1 and MBS = 15) must have been set before executing the instruction. <sup>2:</sup> The low-order two bits of address and the bit address are specified indirectly by using the L register. <sup>3: (</sup>MBE = 1 and MBS = 1) must have been set before executing the instruction. <sup>4:</sup> Accumulator A bit 0 corresponds to BPn. <sup>5:</sup> Write FH into the H register. ### 5.1.4 Digital input / output port operation When data memory operation instructions are executed for the digital input / output ports, port (pin) operation varries according to which mode (input or output) is set. (See table 5.1–3.) This is because as understood from the input / output port structure, data read into the internal bus is data for each pin in the input mode and output latch data in the output mode. (1) Operation when input mode is set Pin data is operated when executing a test instruction such as SKT or an instruction to read 4- or 8-bit port data into the internal bus (IN, OUT, operation, or comparison instruction). When an instruction to transfer the accumulator contents (four or eight bits) to a port or ports is executed (OUT or MOV instruction), the accumulator data is latched in the output latches. The output buffers remain off. When an XCH instruction is executed, pin data is input to the accumulator and the accumulator data is latched in the output latches. The output buffers remain off. When an INCS instruction is executed, data resulting from adding 1 to 4-bit pin data is latched in the output latches. The output buffer remain off. When an instruction to rewrite data memory bitwise is executed, such as SET1, CLR1, or SKTCLR, (the specified bit output latch can be rewritten as specified by instruction), but the contents of the output latch for other bits become undefined. (2) Operation when output mode is set When a test instruction or an instruction to read 4- or 8-bit port data into the internal bus is executed, the output latch contents are operated. When an instruction to transfer the accumulator contents (four or eight bits) is executed, output latch data is rewritten and at the same time as output from the pins. When an XCH instruction is executed, the output latch contents are transferred to the accumulator, and the accumulator contents are held in the output latches and is output from the pins. When an INCS instruction is executed, data resulting from incrementing the output latch contents by one is held in the output latches and output from the pins. When a bit output instruction is executed, the specified output latch bit is rewritten and output from the pin. Table 5.1-3 Operation When Input / Output Ports are Used | Executed | Port (pin) | Port (pin) operation | | | | | | | | |---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|--|--|--|--|--|--| | instruction | Input mode | Output mode | | | | | | | | | SKT ① | Pin data is tested. | Output latch is data tested. | | | | | | | | | AND1 CY, ① OR1 CY, ① XOR1 CY, ① | Operation is performed between pin data and CY. | Operation is performed between output latch data and CY. | | | | | | | | | IN A, PORTn<br>IN XA, PORTn<br>MOV A, @HL<br>MOV XA, @HL | Pin data is transferred to accumulator. | Output latch data is transferred to accumulator | | | | | | | | | ADDS A, @HL ADDC A, @HL SUBS A, @HL SUBC A, @HL AND A, @HL OR A, @HL XOR A, @HL | Operation is performed between pin data and accumulator. | Operation is performed between output latch data and accumulator. | | | | | | | | | SKE A, @HL | Pin data and accumulator contents are compared. | Output latch data and accumulator contents are compared. | | | | | | | | | OUT PORTn, A<br>OUT PORTn, XA<br>MOV @HL, A<br>MOV @HL, XA | Accumulator data is transferred to output latches. (Output buffers remain off.) | Accumulator data is transferred to output latches and output from the pins. | | | | | | | | | XCH A, PORTn<br>XCH XA, PORTn<br>XCH A, @HL<br>XCH XA, @HL | Pin data is transferred to accumulator and accumulator data is transferred to output latches. (Output buffers remain off.) | Data is exchanged between output latches and the accumulator. | | | | | | | | | INCS PORTn<br>INCS @HL | Data resulting from incrementing pin data by one is latched in output latches. | The output latch contents are incremented by one. | | | | | | | | | SET1 ① CLR1 ① SKTCLR ① | The specified bit output latches are rewritten as specified by the instruction, but the output latch contents for other bits are undefined. | The output pin state is changed according to the instruction. | | | | | | | | : Denotes two addressing modes PORTn. bit and PORTn. @L. ## 5.1.5 Internal pull-up resistors Pull-up resistors can be incorporated in the $\mu$ PD75328 port pins except P00 or BP0-BP7. Internal pull-up resistors are specified by using software or mask option. Figure 5.1-7 Pull-Up Register Specification Register Format Table 5.1-4 | Port (pin names) | Internal pull-up resistor specification method | Specification Bit | |---------------------------|-------------------------------------------------------------------------|-------------------| | Port 0 (P01-P03) (Note 1) | Software is used for internal resistor specification in 3-bit units. | POGA.0 | | Port 1 (P10-P13) | | POGA.1 | | Port 2 (P20-P23) | | POGA.2 | | Port 3 (P30-P33) | Software is used for internal resistor specification in 4-bit units. | POGA.3 | | Port 6 (P60-P63) | | POGA.6 | | Port 7 (P70-P73) | | POGA.7 | | Port 8 (P80-P83) | | POGB.0 | | Port 4 (P40-P43) | Mask option is used for internal resistor specification in 1-bit units. | _ | | Port 5 (P50-P53) | mask option is used for internal resistor specification in 1-bit units. | | Note: A pull-up resistor cannot be incorporated in the P00 Pin. ## 5.1.6 Digital input / output port input / output timing Fig. 5.1-8 shows timing of data to output latch and timing of pin data or output latch data input to the internal bus. Fig. 5.1-9 shows the ON timing at specified the internal pull-up resistor by software. Figure 5.1-9 ON Timing of Pull-up Resistor by using Software ## 5.2 Clock Generator The clock generator supplies clocks to CPU and peripheral hardware for controlling the CPU operating mode. ## 5.2.1 Clock generator configuration Fig. 5.2-1 shows a clock generator block diagram. - - 2. f<sup>^</sup><sub>XT</sub> : Subsystem clock frequency 3. PCC : Processor clock control register - 4. SCC: System clock control register - 5. \* denotes instruction execution. Figure 5.2-1 Clock Generator Block Diagram #### 5.2.2 Clock generator function and operation The clock generator produces the following clocks and controls CPU operating modes such as standby: - Main system clock f<sub>x</sub> - Subsystem clock f<sub>xT</sub> - CPU clock ф - Clock to peripheral hardware The clock generator operates according to how the processor clock control register (PCC) and system clock control register (SCC) are set, as described below: - (a) When the RESET signal is generated, the minimum speed mode of the main system clock (15.3 μ/4.19 MHz) is selected. (PCC = 0 and SCC = 0) - (b) When the main system clock is selected, one of three CPU clock frequencies can be selected (0.95 μs, 1.91 μs, and 15.3 μs/ 4.19 MHz) by setting PCC. - (c) When the main system clock is selected, the standby mode (STOP or HALT) can be used. - (d) Subsystem clock is selected by setting SCC.0, and operation can be performed in a very low-speed and low current consumption (122 μs/32.768 kHz). In this case, the PCC setup value does not affect the CPU clock. - (e) When the subsystem clock is selected, main system clock oscillation can be stopped by setting SCC.3. The HALT mode can also be used, but the STOP mode cannot be used. (Subsystem clock oscillation cannot be stopped. - (f) The main system clock is divided to generate a clock supplied to peripheral hardware. The subsystem clock can be supplied directly only to the watch timer. Thus, the watch function and the LCD controlller and buzzer output function which operate using the watch timer clock can also continue operation in the standby mode. - (g) When subsystem clock is selected, the watch timer and LCD controller can continue normal operation. When the main system clock is stopped, other hardware devices than the watch timer or LCD controller cannot be used because they operate according to the main system clock. - (1) Processor clock control register (PCC) PCC consists of four bits; the low-order two bits are used to select CPU clock $\phi$ , and the high-order two bits are used to control CPU operation mode. (See Fig. 5.2-2.) When bit 3 or 2 is set to (1), the standby mode is set. When the standby mode is released by the standby mode release signal, automatically bits 3 and 2 are cleared and the normal operating mode is entered. (For details, see Paragraph 7). The low-order two bits of PCC are set by using a 4-bit memory operation instruction (the high-order two bits are set 0). Bits 3 and 2 are set to (1) by using STOP and HALT instructions respectively. The STOP and HALT instructions can always be executed independently of the MBE contents. CPU clock can be selected only during main system clock operation. When the $\mu$ PD75328 is operated on the subsystem clock, the low-order two bits of PCC becomes invalid, and the CPU clock is fixed to $f_{\chi_T}/4$ . The stop instruction is also enabled only during main system operation. Example 1: To set a machine cycle to 0.95 µs (4.19) MHz). SEL MB15 MOV A. #0011B MOV PCC, A Example 2: To set STOP mode. (Be sure to enter a NOP instruction following the STOP or HALT instruction.) STOP NOP When the RESET signal is generated, PCC is cleared. Figure 5.2–2 Processor Clock Control Register Format ## (2) System clock control register (SCC) SCC consists of four bits; the least significant bit is used to select CPU clock, and the most significant bit is used to control (stop) main system clock oscillation. (See Fig. 5.2–3.) SCC 0 and SCC 3 exist at the same data memory address; the bits cannot be changed at the same time. Thus, SCC 0 and SCC 3 are set by using a bit operation instruction. SCC 0 and SCC 3 can always be operated independetly of the MBE contents. Main system clock oscillation can be stopped by setting SCC 3 only during subsystem clock operation. Main system clock oscillation is stopped by using the STOP instruction during main system clock operation. When the RESET signal is generated, SCC is cleared. Figure 5.2-3 System Clock Control Register Format - Caution 1: Changing the system clock requires a maximum of $1/f_{XT}$ time. To stop main system clock after changing the subsystem clock, set SCC 3 after the machine cycle or cycles listed in Table 5.2–1. - 2: Even if oscillation is stopped by setting SCC 3 during main system clock operation, normal STOP mode is not entered. - 3: When SCC.3 is set to 1, X1 input is connected internally to V<sub>SS</sub>, to avoid leakage current due to crystall oscillator. When the external clock is used in main system clock, do not set SCC.3 to 1. - 4: When the system clock is switched to the subsystem clock it is necessary to disable any interrupt during the time given in table 5.2-1. #### (3) System clock oscillators The main system clock oscillator uses a crystal oscillator (4.194304 MHz standard) or cermanic oscillator connected to the X1 and X2 pins. An external clock can also be input. Figure 5.2-4 External Circuit to Main System Clock Oscillator Caution: When an external clock is input, the STOP mode cannot be set because the X1 pin is connected to V<sub>SS</sub> in the STOP mode. The subsystem clock oscillator uses a crystal oscillator (32.768 kHz standard) connected to the XT1 and XT2 pins. An external clock can also be input. The XT1 pin state can be tested by using watch mode register (WM) bit 3. Figure 5.2-5 External Circuit to Subsystem Clock Oscillator (4) Frequency divider The frequency divider divides the main system clock oscillator output $(f_x)$ and generates various clocks. 5.2.3 System clock and CPU clock setting (1) Time required to change system and CPU clocks The system and CPU clocks can be changed by using the low-order two bits of PCC and the least significant bit of SCC. However, this clock change is not immediatly made after the register are rewritten, and the clock before the clock change is made is used for operation during given machine cycles. Thus, to stop main system clock oscillation, a STOP instruction must be executed or SCC 3 must be set after the change time elapses. Table 5.2-1 Maximum Time Required to Change System and CPU Clocks | | etup val<br>ore cha | | | Setup value after change | | | | | | | | | | | | | |-----|---------------------|-----|----------------------------|-------------------------------------|-------|---------------------------------------------|---------------------------|-------------------|---------------------------------------------|---------------------------|------|---------------------------------------------|--------------------------------------------------------------------|------|--|--| | SCC | PCC | PCC | SCC0 | PCC1 | PCC0 | SCC0 PCC1 PCC0 | | | SCC0 | PCC1 | PCC0 | SCC0 | PCC1 | PCC0 | | | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | Х | Х | | | | | 0 | 0 | | | | 1 machine cycle | | | | 1 machine cycle | | | f <sub>X</sub> machine 64f <sub>XT</sub> cycle (2 machine cycles) | | | | | 0 | 1 | 0 | 8 ma | achine cy | rcles | | | | 8 machine cycles | | | f <sub>X</sub><br>8f <sub>XT</sub><br>(16 m | macl<br>cycle<br>achine c | es | | | | | 1 | 1 | 16 m | 16 machine cycles 16 machine cycles | | | | 16 machine cycles | | | | f <sub>X</sub><br>4f <sub>XT</sub><br>(32 m | macl<br>cycle<br>achine c | es | | | | 1 | x | x | 64f <sub>X1</sub><br>(2 ma | mach<br>cycle<br>achine cy | s | f <sub>X</sub><br>8f <sub>XT</sub><br>(16 m | mach<br>cycle<br>achine c | s | f <sub>X</sub><br>4f <sub>XT</sub><br>(32 m | mach<br>cycle<br>achine c | s | | _ | | | | The values enclosed in parentheses are applied when $f_x = 4.19$ MHz and $f_{XT} = 32.768$ kHz. Remarks: The CPU clock $\Phi$ is supplied to the $\mu$ PD75328 internal CPU. The reciprocal of the clock becomes the minimum instruction time. (The present manual defines it to be one machine cycle.) (2) System and CPU clock change sequence System and CPU clock change is explained using Fig. 5.2–6. - When the RESET signal is generated, the CPU starts operating at the minimum speed of the main system clock (15.3 μs / 4.19 MHz) after the wait time (31.3 ms / 4.19 MHz) to allow time for stabilizing the oscillator. - 2) After enough time has elapsed for the V<sub>DD</sub> pin voltage to rise to an adequate level PCC is rewritten and the µPD75328 operates at the maximum speed. - 3) Turning off the commercial power supply is detected by using interrupt input (INT4 is useful); SCC. 0 is set, and the µPD75328 operates using the subsystem clock. (At the time, a check must have been made to ensure that subsystem clock oscillation has started. After the time required to change to the subsystem clock (32 machine cycles) has elapsed, SCC 3 is set and main system clock oscillation is stopped. - 4) Restoration of the commercial power supply is detected by using an interrupt. SCC. 3 is cleared and main system clock osscillation is started. After the time required to stabilize oscillation has elapsed, SCC. 0 is cleared and the µPD75328 operates at the maximum speed. ## 5.2.4 Clock output circuit (1) Clock output circuit configuration Fig. 5.2-7 shows a clock output circuit block diagram. (2) Clock output circuit function The clock output circuit, which outputs clock pulses from the P22/PCL pin, is used to supply clock pulses to remote control output or peripheral LSIs. Clock pulses are output in the following sequence: - (a) Clock output frequency is selected. Clock output is disabled. - (b) 0 is written into P22 output latch. - (c) Port 2 input/output mode is placed in output mode. - (d) Clock output is enabled. Figure 5.2-7 Clock Output Circuit Block Diagram Remarks: The circuit is designed so as not to output a spurious short-width pulse when changing between clock output enable and disable. (3) Clock output mode register (CLOM) CLOM is a 4-bit register to control clock output. CLOM is set by using a 4-bit memory operation instruction. It cannot be read. Example: To output clock $\Phi$ from PCL/P22 pin. SEL MB15 ; Or CLR1 MBE MOV A, #1000B MOV CLOM, A When the RESET signal is generated, CLOM is cleared and clock output is disabled. Caution: Be sure to write 0 into CLOM bit 2. Figure 5.2-8 Clock Output Mode Register Format (4) Application example to remote control output The μPD75328 clock output function is applicable to remote control output. Remote control output carrier frequency is selected by using the clock frequency selection bit of the clock output mode register. Pulse output is enabled or disabled under software control by using the clock output enable/disable bit. It is designed so that a spurious short-width pulse will not be produced when changing between clock output enable and disable. Figure 5.2-9 Remote Control Output Application Example ## 5.3 Basic Interval Timer The µPD75328 contains an 8-bit basic interval timer which has the following functions: - (a) Reference time generation (four types of time interval) - (b) Wait time selection and count when standby mode is released. - (c) Count read The basic interval timer can also be applied to a watchdog timer to detect program overrun. ## 5.3.1 Basic interval timer configuration Fig. 5.3-1 shows the configuration of the basic interval timer Remarks: \* denotes instruction executing. Figure 5.3-1 Basic Interval Timer Configuration ## 5.3.2. Basic interval timer mode register (BTM) BTM is a 4-bit register for controlling operation of the basic interval timer. BTM is set by using a 4-bit memory operation instruction. Bit 3 can be set individually by using a bit operation instruction. Example 1: To set the interrupt generation interval to 1.95 ms (4.19 MHz). SEL MB15 ; or CLR1 MBE MOV A, # 1111B Example 2: To clear BT and IRQBT (watchdog timer application). SEL MB15 ; or CLR1 MBE SET1 BTM.3 ; BTM BIT 3 is set to 1. When bit 3 is set to 1, the basic interval timer contents are cleared. At the same time, the basic interval interrupt request flag (IRQBT) is also cleared. (The basic interval timer starts.) When the RESET signal is generated, the BTM contents are cleared and interrupt request signal generation is set for the longest interval. Fig. 5.3-2 Basic Interval Timer Mode Register Format ## 5.3.3. Basic interval timer operation The basic interval timer (BT) is incremented each time a pulse is received from the clock generator. When an overflow occurs, the interrupt request flag (IRQQBT) is set. BT count operation cannot be stopped. An interrupt generation time interval can be selected from among four types by setting BTM. (See Fig. 5.3—2.) The basic interval timer and interrupt request flag can be cleared by setting BTM bit 3 to 1 (the interval timer function starts). The basic interval timer (BT) count can be read by using an 8-bit operation instruction. Data cannot be written into BT. #### Caution: To prevent reading of unstable data during count update when reading the basic interval timer count, execute the read instruction twice and compare the results. If they are valid values, the later read value is used as the read result, if they differ from each other completely, reexecute from the beginning. Example: To read the BT count SET1 MBE MB15 SEL MOV HL, #BT BT address is set in HL. LOOP: MOV XA, @HL First read MOV BC, XA MOV XA, @ HL Second read SKE A, C LOOP BR MOV A, X SKE A, B BR LOOP The wait function is provided to stop CPU operation until the basic interval timer overflows in order to allow time for system clock oscillation to become stable when the STOP mode is released. Although the wait time after the RESET signal is generated is fixed, it can be selected by setting BTM when the STOP mode is released by an interrupt. The wait time is selected by setting BTM as shown in Fig. 5.3—2. BTM setting must be performed before the STOP mode is set. (For details, see CHAPTER 7.) ### 5.3.4 Basic interval timer application examples Example 1: To enable basic interval timer interrupt and set interrupt generation interval at 1.95 ms (at 4.19 MHz). SEL MB 15 A, #1111B MOV MOV BTM, A BTM setting and timer function start Interrupt is enabled. EI EI **IEBT** BT interrupt is enabled. ## Example 2: Watchdog timer application A program is divided into serval modules which terminate processing within the BT setup time. BT and IRQBT are cleared at the end of each module. If an interrupt is generated, overrun is asumed to have occured. > SEL MB15 Initial-MOV A. #1101B : 7.8 ms interval is set. izatiion MOV BTM, A BTM setting and timer function start ΕI EEI **IEBT** Example 3: To set the wait time, when the STOP mode is released, using an interrupt to 7.8 ms. SEL MB15 or CLR1 MBE A, #1101B MOV MOV BTM. A BTM ← 1101B STOP STOP mode is set NOP ## Example 4: To set the high-level width of a pulse input to INT4 interupt (both rising and falling edge detection). (The pulse width must not exceed the BT setup value. The BT setup value must be 7.8 ms or more.) < INT4 interrupt routine (MBE = 0) > | LOOP: | MOV<br>MOV<br>SKE<br>BR | XA, BT<br>BC, XA<br>XA, BT<br>A, C<br>LOOP | ; | First read<br>Data is stored.<br>Second read | |-------|-------------------------|--------------------------------------------|---|----------------------------------------------| | | MOV<br>SKE<br>BR | A, X<br>A, B | | | | | SKT<br>BR | LOOP<br>PORT0.0<br>AA | ; | P00=1?<br>NO | | | MOV<br>MOV | XA, BC<br>BUFF, XA | ; | Data is stored in data memory. | | | CLR1<br>RETI | FLAG | | | | AA: | MOV<br>MOV<br>SUBC | HL, #BUFF<br>A, C<br>A, @HL | | | | | INCS<br>MOV | L<br>C, A | | | | | MOV<br>SUBC<br>MOV | A, X<br>A, @HL<br>B, A | | | | | MOV<br>MOV | XA, BC<br>BUFF, XA | ; | Data is stored. | | | SET1<br>RETI | FLAG | ; | Data existence flag is set. | ## 5.4 Watch Timer The $\mu PD75328$ incorporates a watch timer (one channel) which has the following function: - (a) The test flag (IRQW) is set at 0.5 s time intervales. The standby mode can be released using IRQW. - (b) The main system and subsystem clocks can be assigned 0.5-s intervals. - (c) In the rapid feed mode, time intervals multiplied by 128 (3.91 ms) are enabled. The mode is useful for program debugging and testing. - (d) A fixed frequency (2.048 kHz) can be output to P23/BUZ. It can be used for sounding the buzzer and trimming the system clock oscillation frequency. - (e) Since the scaler can be cleared, the watch can be started at zero seconds. # 5.4.1 Watch timer configuration Fig. 5.4-1 shows a watch timer block diagram. The values enclosed in parentheses are applied when $f_{\chi}$ = 4.194304 MHz and $f_{\chi T}$ = 32.768 kHz. Figure 5.4-1 Watch Timer Block Diagram ### 5.4.2 Watch mode register The watch dog timer (WM) consists of eight bits to control the watch timer. Fig. 5.4–2 shows the watch mode register format. The watch mode register (except bit 3) is set using an 8-bit operation instruction. Bit 3 is used to test the XT1 pin input level. The input level to the XT1 pin can be tested by making a bit test. When the RESET signal is generated, all bits except bit 3 are cleared. Example: To produce time using the main system clock (4.19 MHz). To enable buzzer output. CLR1 MBE MOV XA. #84H MOV WM, XA ; WM set Addroce | Address | | | | | | | | | Symbol | |---------|-----|---|---|---|-----|-----|-----|-----|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | F98H | WM7 | 0 | 0 | 0 | wмз | WM2 | WM1 | WM0 | WM | Count clock (fw) selection bit | | WM0 | 0 | System clock dividing output $\frac{f_X}{128}$ is selected. | |--|-----|---|-------------------------------------------------------------| | | | 1 | Subsystem clock f <sub>XT</sub> is selected. | ## Operation mode selection bit | WM1 | 0 | Normal watch mode (IRQW is set by using $\frac{f_W}{2^{14}}$ , 0.5 s) | |-------|---|------------------------------------------------------------------------| | VVIVI | 1 | Rapid feed watch mode (IRQW is set by using $\frac{f_W}{2}$ , 3.91 ms) | ## Watch operation enable/disable bit | WM2 | 0 | Watch operation is stopped (divider is cleared). | |--------|---|--------------------------------------------------| | VVIVIZ | 1 | Watch operation is enabled. | ## Input level to XT1 pin (bit test only is enabled) | WM3 | 0 | Input level to XT1 pin is low. | |--------|---|---------------------------------| | VVIVIS | 1 | Input level to XT1 pin is high. | ## BUZ output enable/disable bit | WM7 | 0 | BUZ output is disabled. | |-------|---|-------------------------| | VVIVI | 1 | BUZ output is enabled. | Figure 5.4-2 Watch Mode Register Format # 5.5 Timer/event counter configuration The μPD75328 incorporates a timer/event counter (one channel) as shown in Fig. 5.5–1. The timer/event counter functions are as follows: - (a) Programmable interval timer operation - (b) Any desired frequency square wave output to PTO0 pin - (c) Event counter operation - (d) TIO pin input is divided by N output to PTO0 pin (scaler operation). - (e) Real shift clock supply to serial interface circuit - (f) Count read function Figure 5.5–1 Timer/Event Counter Block Diagram ## 5.5.2 Basic configuration and operation of timer/event counter The timer/event counter operation mode can be selected by using the timer/event counter mode register (TM0). The basic configuration and operation of the timer/event counter are explained below: - (1) Count pulse CP is selected by setting TM0 and input to the 8-bit count register T0. - (2) To is a binary 8-bit up counter incremented by one when CP is input. It is cleared when the RESET signal is generated, TM0 bit 3 is set (timer start), or coincidence signal is generated. To can be read at any time using an 8-bit memory operation instruction, but cannot be written - (3) The modulo register TMOD0 consists of eight bits to determine the T0 count. A value is set in TMOD0 using an 8-bit memory operation instruction, but TMOD0 cannot be read. When the RESET signal is generated, TMOD0 is initialized to FFH - (4) The comparator compares the T0 and TMOD0 contents. If they match, it generates a coincidence signal and sets the interrupt request flag (IRQT0) - Fig. 5.5-2 shows the count operation timing. Figure 5.5-2 Count Operation Timing Chart ## 5.5.3 Timer/event counter mode register (TM0) and timer/event counter output enable flag (TOE0) The mode register (TM0) consists of eight bits to control the timer/event counter. Fig. 5.5–3 shows the timer/event counter mode register format. The timer mode register is set by using an 8-bit memory operation instruction. Bit 3 is a timer start bit which can be set individually. Bit 3 is reset to 0 automatically when timer operation starts. Example 1: To start the timer in interval timer mode with CP = 4.09 kHz. SEL MB15 or CLR1 MBE MOV XA. #01001100B MOV TM0.XA TM0<sup>→</sup> 4CH Example 2: To restart the timer according to how the timer mode register is set. When the RESET signal is generated, all the timer mode register bits are cleared. The timer/event counter output enable flag (TOE0) controls enable/disable of outputting the timer out F/F (TOUT F/F) state to the PTO0 pin. (See Fig. 5.5–4.) It is operated by using bit operation instruction and is enable to be writing. The timer out F/F (TOUT F/F) is inverted by the coincidence signal received from the comparator. The timer out F/F is reset using an instruction to set timer mode register (TM0) bit 3. When the RESET signal is generated, TOE0 and TOUT F/F are cleared. Remarks: The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. Figure 5.5-3 Timer/Event Coumter Mode Register Format Figure 5.5-4 Timer/Event Counter Output Enable Flag Format #### 5.5.4 Timer/event counter operation mode The timer/event counter operates in the count operation stop or count operation mode depending on how the mode register is set. The following are always enabled independently of how the mode register is set - 1) TIO pin signal input and test. (P13 pin input test can be made.) - 2) Output of timer out F/F state to PTO0. - 3) Modulo register (TMOD0) setting. - 4) Count register (TMODO) setting - 5) Interrupt request flag (IRQT0) setting, clear, and test - (a) Count operation stop mode The count operation stop mode is set when TM0 bit 2 is set to 0. Since count pulse (CP) supply to the count register is stopped, count operation is not performed (b) Count operation mode The count operation mode is set when TM0 bit 2 is set to 1. Count pulses selected by using bits 4 to 6 are supplied to the count register, and count operation is performed as shown in Fig. 5.5–2. Normally, timer operation is started by 1) setting a count value in the modulo register (TMOD0), then 2) setting the operation mode, count clock, and start indication in the mode register (TM0). The modulo register is set by using an 8-bit data transfer instruction. Caution: Set a value other than 0 in the modulo register. Example: To set 3FH in channel 0 modulo register. SEL MB15 ; or CLR1 MBE MOV XA, #3FH MOV TMOD0, XA Figure 5.5-5 Operation in Count Operation Mode ## 5.5.5 Timer/event counter time setting "Timer setup value" (period) is equal to "modulo register contents + 1" divided by "count pulse frequency" selected by setting the timer mode register. $$T(s) = \frac{n+1}{F_{CP}}$$ T (s) : Timer setup value (seconds) F<sub>CP</sub> (Hz): Count pulse frequency (Hz) n: Modulo register value (\*\* - \*\*) : Modulo register value (n ≠ 0) Once the timer is set, an interrupt request signal (IRQT0) is generated at the setup time intervals. Table 5.5-1 lists the resolution and maximum setup value (time when FFH is set in the modulo register) of the timer/event counter for each count pulse. Example: To produce 30 ms time intervals. (f $_{\rm X}$ = 4.194304 MHz) Use the mode with the maximum setup time 62.5 ms. $$\frac{30 \text{ ms}}{244 \,\mu\text{s}} = 122.9 = 7\text{AH}$$ Set 79H in the modulo register. SEL MB15 XA, #79H MOV MOV TMODO, XA Table 5.5-1 Resolution and Maximum Setup Value (4.19 MHz) | Mode register | | | Timer channel 0 | | |---------------|------|------|-----------------|--------------------| | TMO6 | TMO5 | TMO4 | Resolution | Maximum setup time | | 1 | 0 | 0 | 244 μs | 62.5 ms | | 1 | 0 | 1 | 61.1 μs | 15.6 ms | | 1 | 1 | 0 | 15.3 μs | 3.91 ms | | 1 | 1 | 1 | 3.81 μs | 977 μs | ### 5.5.6 Caution on timer/event counter application ### (1) Error at timer start An error with a maximum length of one clock period of the count pulse (CP) for the value calculated in 5.5.5 occurs in the time until a coincidence signal is generated after the timer starts (TM0.3 is set). This is because clearing of the count register is not synchronized with CP as shown in Fig. 5.5–6. Figure 5.5-6 Error at Timer Starting ### (2) Caution at timer start Normally, the count register T0 and interrupt request flag IRQT0 are cleared when the timer starts (TM0 bit 3 is set). However, if the timer is placed in the operation mode, and IRQT0 setting and timer start occur simultaneously, IRQT0 may be unable to clear. There is no problem when IRQT0 is used for a vectored interrupt. In IRQT0 test application, however, a problem arises such than IRQT0 is set although the timer has been started. Thus, to start the timer at IRQT0 timing, stop the timer once (by setting TM0 bit 2 to 0), then restart it, or start the timer twice. Example: Timer start at IRQT0 timing may be set SEL MB15 ; or CLR1 MBE MOV XA, #0 MOV TM0, XA ; Timer stop MOV XA, #4CH MOV XA, #4CH MOV TM0. XA MOV TM0, XA ; Restart SEL MB15 ; or CLR1 MBE SET1 TM0.3 SET1 TM0.3 ; Restart # (3) Error at count register read or The count register contents can be read at any time using an 8-bit data memory operation instruction. During execution of the instruction, count pulse change is held and count register change is suppressed. Thus, if the count pulse signal source is input to TIO, count pulses as long as the instruction execution time are deleted. (This symptom does not occur if the internal clock is used for count pulses because they are synchronized with the instruction.) Therefore, if TI0 is input as a count pulse and the count register contents are read, signals having a pulse width that prevents miscount, even if count pulses are deleted, must be input. Since the count hold period in read instruction execution is one machine cycle, the pulse width input to the TI0 pin must be longer than one machine cycle. ### (4) Caution at count pulse change If the timer mode register is rewritten and count pulse change is made, its specification becomes effective immediately after instruction execution. A count pulse (1) or 2) in the timing chart shown below) may occur depending on the clock combination when the count pulse changed. In this case, a miscount may occur or the count register contents may be destroyed. To change count pulse, be sure to set count mode register bit 3 to 1 and restart the timer at the same time. ### (5) Operation after modulo register change The modulo register is changed when an 8-bit data memory operation instruction is executed. If the value appearing after the modulo register is changed and becomes smaller than the count register value, the count register continues counting and overflows, then restarts counting from 0. Thus, if the value after the modulo register is changed (m) and becomes smaller than the value before it was changed (n), the timer must be restarted after the modulo register is changed. # 5.5.7 Timer/event counter application - (1) Timer 0 is applied to an interval timer generating an interrupt at 50 ms intervals. - The high-order four bits of the mode register are set to 0100B and a maximum setup time of 62.5 ms is selected. - The low-order four bits of the mode register are set to 1100B. - The modulo register setup value is as follows: $$\frac{50 \text{ ms}}{244 \text{ us}} = 205 = \text{CDH}$$ Example: SEL MB1 SEL MB15 ; or CLR1 MBE MOV XA, #0CCH MOV TMODO, XA ; Modulo is set. MOV XA, #01001100B MOV TM0, XA ; Mode is set and timer is started. ΕI : Interrupts is enabled. EI IETO :T ; Timer interrupt is enabled. Remarks: In this application, the TI0 pin can be used as an input pin. (2) When the number of pulses input from the TI0 pin reaches 100, an interrupt is generated. (The pulses are active high.) - The high-order four bits of the mode register are set to 0000 and the rising edge is selected. - The low-order four bits of the mode register are set to 1100B. — The modulo register is 99 = 100 - 1. Example: SEL MB15 ; or CLR1 MBE MOV XA.#100-1 MOV TMOD0, XA ; Modulo is set. MOV XA, #00001100B MOV TM0, XA EI - EI IETO ; INTT0 is enabled. #### 5.6 Serial Interface #### 5.6.1 Serial interface configuration The µPD75328 has a clocked serial interface (CSI) as shown in Fig. 5.6-2. #### 5.6.2 Serial interface functions The µPD75328 serial interface includes the three modes described in (1) to (3) below. Since the serial clock line $\overline{\text{SCK}}$ and serial data bus lines SB0/SB1 enable software to determine the output level, any desired transfer format can be handled. # (1) 3-line serial I/O mode - Three lines of serial clock SCK, serial output SO, and serial input SI - Clock synchronous 8-bit send and receive (simultaneous send and receive) - The serial transfer top can be changed between the most and least significant bits (MSB and LSB). - This mode enables the $\mu$ PD75328 to be connected to the $\mu$ PD7500 series, $\mu$ COM-75X family, $\mu$ COM-87 family, and various peripheral I/O devices. - (2) SBI (serial bus interface) mode - This mode conforms to the NEC serial bus format. - Communication can be made with a number of devices by using the serial clock SCK and serial data bus SB0 or SB1 lines. - Address, command, and data can be transferred, and a hardware function for discriminating the signals is included. (See Fig. 5.6-2.) - The acknowledge, busy signal output function and the wake-up function for handshaking are included. Fig. 5.6-1 SBI System Configuration Example #### (3) 2-line serial I/O mode - Communication can be made by using the serial clock SCK and serial data bus SB0 or SB1 lines. - Communication can be made with a number of devices by using software to control the output level to the two lines. Any desired communication format can be handled. II-4-81 # Figure 5.6-3 SBI Transfer Timing Chart ### 5.6.3 Main register functions # (1) Serial operating mode register (CSIM) The serial operation mode register (CSIM) consists of eight bits that specify the serial interface operating mode, serial clock, wake-up function, etc. CSIM is set using an 8-bit memory operation instruction. The high-order three bits of CSIM can be set bitwise using the bit name. Bit 6 enables bit test only. Data written into the bit becomes invalid. #### Example 1: To select f<sub>v</sub>/2<sup>4</sup> for serial clock, generate a serial interrupt IRQCSI at the end of each serial transfer, and make serial transfer in the SBI mode using the SB0 pin as the serial data bus line. > MB15 SEL or CLR1 MBE XA, #10001010B MOV CSIM, XA MOV CSIM 10001010B ### Example 2: To enable serial transfer conforming to the CSIM contents. SEL MB15 or CLR1 MBE SET1 CSIE Wake-up function specification bit (WUP): ### (a) When WUP=0 IRQCSI is set each time a serial transfer ends. WUP is set to 0 during normal transfer. ### (b) When WUP = 1 WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register (SVA) value (wake-up state). When the received address is not its own, an unnecessary interrupt will not be generated. The $\overline{ACK}$ signal is not output either. The SB0 (SB1) pin is placed in a high impedance state independent of the SO the latch state. When the RESET signal is generated, all bits are cleared. Fig. 5.6-4 shows the format of the serial operation mode register. | Address | | | | | | | | | Symbol | |---------|------|-----|-----|-------|-------|-------|-------|-------|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | . 1 | 0 | | | FE0H | CSIE | COI | WUP | CSIM4 | CSIM3 | CSIM2 | CSIM1 | CSIM0 | CSIM | #### Serial clock selection bits (W) | COIMI | CSIMO | | SCK pin mode | | | | |-------|-------------|-------------------------------------------------------------------------------------|---------------------------------|-------------------|------------------------|---------------| | CSIWI | CSIM1 CSIM0 | SIIVI CSIIVIO | 3-line serial I/O mode | SBI mode | 2-line serial I/O mode | SCK piri mode | | 0 | 0 | SCK pin input clock from the external | | | Input | | | 0 | 1 | Timer/event counter output (TC | Timer/event counter output (TO) | | | | | 1 | 0 | f <sub>x</sub> /2 <sup>4</sup> (262 kHz) | | 6 (06 (CE E LLI=) | Output | | | 1 | 1 | f <sub>\chi/2<sup>3</sup> (524 kHz) f<sub>\chi/2</sub><sup>6</sup> (65.5 kHz)</sub> | | | | | The values enclosed in parentheses are applied when $f_X = 4.19$ MHz. # Serial interface operating mode selection bits (W) | CSIM4 | СЅІМЗ | CSIM2 | Operating mode | Shift register bit order | SO pin function | SI pin function | | |-------|-----------|--------------------------|---------------------------------------------------------|------------------------------------------------------|---------------------------------------------------|---------------------------------------------------|--| | | | 0 | | SIO <sub>7-0</sub> XA (transfer starts at MBS) | 20/200 | 01/000 | | | X | 0 | 0 3-line serial I/O mode | | SIO <sub>0-7</sub> XA (transfer starts at LSB) | SO/PO2<br>(CMOS output) | SI/PO3<br>(input) | | | 0 | | | ODIdi- | CIOVA | SB0/PO2<br>(N-channel open drain<br>input/output) | PO3 input | | | 1 | (transfer | | SIO <sub>7-0</sub> ** XA<br>(transfer starts<br>at MSB) | PO2 input | SB1/PO3<br>(N-channel open drain<br>input/output) | | | | 0 | | | O line and all VO made | SIO 45 VA | SB1/PO2<br>(N-channel open drain<br>input/output) | PO3 input | | | 1 | 1 | 1 | 2-line serial I/O mode | SIO <sub>7-0</sub> XA<br>(transfer starts<br>at MSB) | PO2 input | SBI/PO3<br>(N-channel open drain<br>input/output) | | (to be continued) Fig. 5.6-4 Serial Operation Mode Register Format # Wake-up function specification bit (W) | | 0 | IRQCSI is set each time a serial transfer ends in each mode. | |-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WUP | 1 | WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register data (wake-up state). SB0 (SB1) is placed in the high impedance state | #### Coincidence signal received from address comparator (R (bit test is only enabled)) Note 1, Note 2 | COL | 0 | Slave address register and shift register data mismatch. | |-----|-----|----------------------------------------------------------| | COI | - 1 | Slave address register and shift register data match. | ### Serial interface operation enable/disable specification bit (W) Note 3 | | | Shift register operation | Serial clock counter | IRQCSI flag | SO/SB0 and SI/SB1 pins | |------|---|------------------------------|----------------------|-------------|------------------------------------------------------| | | 0 | Shift operation is disabled. | Clear | Hold | Port 0 function only | | CSIE | 1 | Shift operation is enabled. | Count operation | Can be set. | Also used for port 0 according to each mode function | #### Figure 5.6-4 Serial Operation Mode Register Format (cont'd) #### Notes: - 1. COI is only valid before serial transfer starts or after it is complete. An undefined value is read during serial transfer. - 2. Data written into COI is ignored. - 3. To use PO1/SCK pin as an input port, set the following below. - Set CSIM0 and CSIM1 bits to 0. (PO1/SCK pins are set to input mode.) - Set CSIE bit to 0. (Stop the serial interface operation.) When CSIM0=CSIM1=0 and CSIE=1 or CSIM0-CSIM1≠0 and CSIE=0, PO1/SCK pins are output to high level. Remarks: (W): Data write is only enabled. (R): Data read is only enabled. (2) Serial bus interface control register (SBIC) The 8-bit serial bus interface control register (SBIC) consists of the serial bus state control bits and flags indicating the states of input data from serial bus. It is mainly used in the SBI mode. Fig. 5.6–5 shows the SBIC format. SBIC is set or tested by using a bit operation (manipulation) instruction. When the RESET signal is generated, all the SBIC bits are cleared. #### Cautions: - 1. SBIC cannot be set by using 4- or 8-bit memory operation instruction. - 2. In the 3- or 2-line serial I/O mode, use only the following two bits for SO latch control: - (a) Bus release trigger bit (RELT): To set SO latch - (b) Command trigger bit (CMDT): To clear SO latch - 3. For the bus release, command, acknowledge, and busy signals, see 5.6.5 (3). ### Example 1: To output command signal. SEL MB15 ; or CLR1 MBE SET1 CMDT Example 2: To test RELD and CMDD and determine the receive data type for appropriate processing. SEL MB15 SKF RELD ; RELD test BR IADRS SKT CMDD ; CMDD test BR IDATA CMD: ... ; Command transfer DATA: ... ; Data transfer ADRS: ... ; Address transfer | Address | | | | | | | | | Symbol | |---------|------|------|------|------|------|------|------|------|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | · | | FE2H | BSYE | ACKD | ACKE | ACKT | CMDD | RELD | CMDT | RELT | SBIC | # Bus release trigger bit (W) | RELT | SO latch is set to 1 by setting the bit. It it used to output bus release signal. After SO latch is set, the bit is | |------|---------------------------------------------------------------------------------------------------------------------| | | automatically cleared. | # Command trigger bit (W) | CMDT | SO latch is cleared by setting the bit. It is used to output | t a command signal. After SO | latch is cleared, the | |------|--------------------------------------------------------------|------------------------------|-----------------------| | 1 | bit is automatically cleared. | | | ### Bus release detection flag (R) | RELD | Clear condition<br>(RELD=0) | When the transfer start is indicated. When the address received after the bus is released dies not match the slave address register (SVA) data. When the RESET signal is input. | |------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Setting condition<br>(RELD=1) | When the address received after the bus is released matches the slave address register data. (Wake up) | # Command detection flag (R) | CMDD | Clear condition<br>(CMDD=0) | When the transfer start is indicated. When the <u>bus rel</u> ease signal is detected. When the RESET signal is input. | |------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------| | | Setting condition (CMDD=1) | When the command signal is detected. | # Acknowledge trigger bit (W) | A | CKT | Used only after transfer | Acknowledge signal is output during one clock period of SCK | |---|-----|--------------------------|-------------------------------------------------------------| | | | completion | immediatly after execution of the set instruction. | # Remarks: - 1. ACKT is automatically cleared after acknowledge signal is output. - 2. ACKT cannot be cleared using software. 3. To set ACKT, set ACKE to 0. Acknowledge enable bit (R/W) | | 0 | Automatic acknowledge signal output is disabled (the signal can be output by setting the acknowledge trigger bit ACKT). | | | | | |------|---|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | ACKE | | Before transfer completion | Acknowledge signal is output during the ninth clock period of SCK (automatically output by presetting ACKE to 1). | | | | | | 1 | After transfer completion | Acknowledge signal is output during one clock period of SCK immediately after execution of the set instruction (automatically output by presetting ACKE to 1). | | | | # Acknowledge detection flag (R) | ACKD | Clear condition<br>(ACKD=0) | When the <u>transfer</u> is started. When the RESET is input. | |------|--------------------------------|-------------------------------------------------------------------| | ACKD | Setting conditions<br>(ACKD=1) | When the acknowledge signal is detected. | # Synchronous busy enable bit (R/W) | BSYE | 0 | Synchronous busy signal output is disabled. Synchronous busy signal output is stopped in synchronization with the SCK falling edge immediately after execution of the clear instruction. | |------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 | Synchronous busy signal is output on the SCK falling edge following an acknowledge signal. | # Remarks: (R): Read is only enabled. (W): Write is only enabled. (R/W): Both read and write are enabled. Figure 5.6-5 SBIC Format Figure 5.6-6 RELT, CMDT, RELD, CMDD Operation Set after transfer completion Figure 5.6-7 ACKT Operation b. When set after completion of transfer c. When ACKE = 0 upon completion of transfer d. When the period of ACKE = 1 is short Figure 5.6–8 ACKE Operation falling edge. rigule 5.0-10 B5 12 Operation ### (3) Slave address register (SVA) When the $\mu$ PD75328 is connected to the serial bus as a slave device in the SBI mode, the 8-bit slave address register (SVA) is used to set the slave address of the $\mu$ PD75328. The SVA value is compared with received 8-bit data by the address comparator. If a match is found between them, serial operating mode register (CSIM) bit 6 (COI) is set to 1. If a match is not found when the address is received, the bus release detection flag (RELD) is cleared. When WUP = 1, IRQCSI is set only if a match is found (wake-up is detected). This interrupt request can be used to know that a communication request is sent from the master to $\mu$ PD75328. SVA can also be used to detect an error when the $\mu PD75328$ sends address, command, or data as a master device. (See 5.6.6.) SVA is set using an 8-bit memory operation instruction. It can only be written. When the RESET signal is generated in a mode which is not standby, the SVA value becomes undefined. ## 5.6.4 Signals in SBI mode Tables 5.6-1 and 5.6-2 list the signals used in the SBI mode. Table 5.6-1 Signals in SBI Mode (I) | | Output | | | Output | Flag | | |----------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | Signal name | device | Definition | Timing chart | condition | influence | Explaination | | Bus release<br>signal<br>(REL) | Master | SB0 ( <u>SB1</u> ) rising edge<br>when SCK = 1 | (Figure 1) | RELT is set. | <ul><li>RELD is set.</li><li>CMDD is cleared.</li></ul> | The signal is followed<br>by CMD signal output<br>indicating that the<br>send data is an address | | Command<br>signal<br>(CMD) | Master | SB0 (SB1) falling<br>edge when SCK = 1 | (Figure 2) | CMDT is set. | • CMDD is set. | i) After REL signal is<br>output, send data<br>is an address.<br>ii) When REL signal is<br>not output, send<br>data is a command. | | Acknowledge<br>sign <u>al</u><br>(ACK) | Master/<br>Slave | Low signal output to SB0 (SB1) during one clock period of SCK after completion of serial reception | (Figure 3) | 1 ACKE = 1<br>2 ACKT is<br>set. | • ACKD is-<br>set. | Completion of reception | | Bus <u>y sign</u> al<br>(BUSY) | Slave | (Synchronous busy<br>signal)<br>Low signal output to<br>SB0 (SB1) following<br>acknowledge signal | | • BSYE = 1 | . – | Serial reception cannot<br>be done because<br>processing is being<br>performed. | | | | (Asynchronous busy signal) Low signal output to SB0 (SB1) (except during serial transfer). It is not synchronized with SCK. | | CMDT is set. | - | | | Ready signal<br>(READY) | Slave | High signal output to<br>SB0 (SB1) before<br>start or after completion<br>of serial transfer | | 1 BSYE = 0<br>2 Execution<br>of SIO data<br>write instruc-<br>tion (transfer<br>start indication) | _ | Serial reception can be done. | Table5.6-2 Signals in SBI Mode (II) | Signal name | Output<br>device | Definition | Timing chart | Output<br>condition | Flag<br>influence | Explanation | |--------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------| | Ser <u>ial clo</u> ck<br>(SCK) | Master | Synchronous clock to output address, command, data, ACK signal, synchronous BUSY signal, etc. Address, command, or data is transferred with the first eight. | (Figure 4) | Execution of<br>SIO data write<br>instruction<br>when CSIE =1<br>(serial transfer<br>start<br>indication)<br>(Note 2) | IRQCSI is<br>set (on the<br>rising edge<br>of ninth<br>clock).<br>(Note 1) | Signal output timing<br>to serial data bus | | Address<br>(A7–0) | Master | 8-bit data transferred<br>in synchronization<br>with SCK after REL<br>and CMD signals are<br>output. | (Figure 5) | | (Note 1) | Slave device address<br>value on serial bus | | Command<br>(C7–0) | Master | 8-bit data transferred in synchronization with SCK after CMD signal only is output (REL signal is not output). | (Figure 6) | | None | Indication message<br>sent to slave device | | Data<br>(D7–0) | Master<br>or<br>Slave | 8-bit data transferred<br>in synchronization<br>with SCK when neither<br>REL nor CMD signal<br>is output. | (Figure 7) | | None | Numeric data<br>processed by slave<br>or master device | When WUP = 0, IRQCSI is always set on the ninth clock $\overline{SCK}$ rising edge. When WUP = 1, IRQCSI is set only when the received address matches the value in the slave address register (SVA). 2. In the BUSY state, transfer is started after the READY state is set. 5.6.5 Serial interface operation The serial interface includes the following four operating modes. - Operation stop mode - 3-line serial I/O mode - SBI mode - 2-line serial I/O mode Table 5.6-3 Serial Interace Operation Mode | CSIM7 | CSIM3 | CSIM2 | Operating mode | |-------|-------|-------|-------------------| | 0 | _ | | Operation stop | | 1 | 0 | _ | 3-line serial I/O | | 1 | 1 | 0 | SBI mode | | 1 | 1 | 1 | 2-line serial I/O | ### (1) Operation stop mode When CSIE = 0, the serial interface is placed in the operation stop mode. In this mode, no serial transfer is done. The operation stop mode is set when the serial interface is not used, so that the power consumption is reduced. In this mode, the shift register does not perform shift operations and can be used as a normal 8-bit register. All the P01/SCK, P02/SO/SB0, and P03/SI/SB1 pins are placed in the high impedance state and used only for the input port function. The P01/SCK pin is placed in the state listed in Table 5.6-4 according to how CSIM1 and CSIM0 are set. Table 5.6-4 CSIM1 and CSIM0 Settings | CSIM1 | CSIM0 | Serial clock | P01/SCK pin state | |-------|-------|----------------|------------------------------------------| | 0 | 0 | External clock | High impedance | | 0 | 1 | | A high level is output. | | 1 | 0 | Internal clock | However, a serial clock is output during | | 1 | 1 | | serial transfer. | Note: For the serial clock, see Fig. 5.6-4. When the RESET signal is generated, the operation stop mode is set. #### (2) 3-line serial I/O mode The 3-line serial I/O mode is compatible with the mode used by the μPD7500 series or other μCOM-75X family devices. Fig. 5.6-11 shows the 3-line serial I/O mode operation timing. Serial transfer start is indicated by executing an instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. In this mode, shift register shift operation is performed in synchronization with the serial clock (SCK) falling edge, and send data is held in the SO latch and output from the SO pin. The receive data input to the SI pin is latched in the shift register on the rising edge of SCK. Since the SO pin is used as a CMOS output and outputs the SO latch state, the SO pin output state can be handled by setting the RELT and CMDT bits. However, do not try to change it during serial transfer. The SCK pin output state can be controlled if the P01 output latch is operated in the output mode (internal clock mode), as described in 5.6.7. A serial clock can be selected from among four clocks, as listed in Table 5.6-5, by setting the mode register. Normally, shift operation is started by: 1) Setting the operating mode and serial clock selection data in the mode register (CSIM) 2) Setting transfer data in the shift register (SIO) (serial operation is started by executing the SIO data write instruction) Serial transfer automatically stops at the end of 8-bit transfer, and the interrupt request flag (IRQCSI) is set. Table 5.6-5 Serial CLock Selection and Application | Mode register S | | Serial clock | Timing at which shift register can be | Application | | |-----------------|-----------|--------------------------------|---------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------| | CSIM<br>1 | CSIM<br>0 | Source | Serial clock mask | ock mask read/written and serial transfer can be started | | | 0 | 0 | External SCK | Automatic mask | Only when serial transfer stops or SCK is high. | Slave CPU | | 0 | 1 | TOUT F/F | at the end of 8-bit<br>data transfer. | (Note) | Half-duplex<br>asynchronous<br>transfer (under<br>software control) | | 1 | 0 | f <sub>X</sub> /2 <sup>4</sup> | | | Medium-speed serial transfer | | 1 | 1 | f <sub>X</sub> /2 <sup>3</sup> | | | High-speed<br>serial transfer | Note: The serial transfer stops in the opertaion stop mode or when the serial clock is masked after 8-bit transfer has been made. The shift register is read and written using 8-bit transfer instructions. At that time, LSB and MSB can be inverted by setting CSIM bit 2. This function enables the transfer top bit to be changed between LSB and MSB. #### Evample: At the same time RAM data specified in the HL register pair is transfered to SIO, the SIO data is read into the accumulator, and serial transfer is started. MOV XA, @HL ; Send data is taken out of RAM. SEL MB15 XCH XA, SIO ; or CLR1 MBE ; Send data and receive data are exchanged, and transfer is started. The transfer top bit LSB or MSB is selected by changing the bit order in writing data into the shift register. The shift order of the shift register bit is always the same. Thus, even if the transfer top bit is changed (LSB to MSB or MSB to LSB) after data is written into the shift register, the data is transferred in the bit order specified before the transfer top bit is changed. Fig. 5.6-12 3-line I/O Mode Format # (3) SBI mode The SBI mode enables the µPD75328 to communicate with a number of devices by using the SCK and SB0 or SB1 lines. Figs. 5.6-13 to 5.6-15 show the timing of operations according to the type of data to be transferred. In the SBI mode, indication of serial transfer start is also given by executing the instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. Shift register shifting is made in synchronization with the serial clock ( $\overline{SCK}$ ) falling edge, and send data is held in the SO latch and output from the SB0/P02 or SB1/P03 pin starting at MSB. Receive data input to the SB0 or SB1 pin is latched in the shift register on the rising edge of $\overline{SCK}$ . The SB0 or SB1 pin specified for the serial data bus is used as N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off. By writing FFH into SIO and shifting it, the N-channel transistor can always be turned off during transfer. When the wake-up function specification bit (WUP) is set to 1, however, the N-channel transistor is always turned off, and FFH need not be written into SIO before reception. Fig. 5.6-13 SBI Mode Timing (Address Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.6-14 SBI Mode Timing (Command Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.6-15 SBI Mode Timing (Data Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. ### (4) 2-line serial I/O mode The 2-line serial I/O mode is used for communications using the SCK and SB0 or SB1 lines. The mode can handle any desired communication format by using software to control the SCK and SB0 or SB1 pin output levels. Fig. 5.6-16 shows the 2-line serial I/O mode timing. Serial transfer start indication is given by executing the instruction writing data into the shift register (SIO), MOV or XCH. Be sure to give start indication when CSIE = 1. Shift register shifting is done in synchronization with the falling edge of the serial clock (SCK), and send data is held in the SO latch and output from the SB0/P02 or SB1/P03 pin starting at MSB. Receive data input from the SB0 or SB1 pin is latched in the shift register on the SCK rising edge. The SB0 or SB1 pin specified for the serial data bus is used as an N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off, thus FFH is previously written into SIO. Since the SB0 or SB1 pin outputs the SO latch state, the SB0 or SB1 pin output state (high impedance or low level) can be controlled by setting the RELT and CMDT bits. However, do not change it during serial transfer. In the output mode (internal clock mode), the SCK pin output state can also be controlled by using the P01 output latch, as described in 5.6.7. Fig. 5.6-16 2-line Serial I/O Mode Timing #### 5.6.6 Error detection Since the data of the sending serial bus SB0 or SB1 is also read by the shift register SIO of the device which sends data in the SBI or 2-line serial I/O mode, a send error can be detected as described below: (1) SIO data comparison before the start of a send and after the end of a send If both the pieces of data do not match, it is determined that a send error occurred. (2) Use of slave address register (SVA) Send data is also set in SVA. After the completion of a send, the COI bit (coincidence signal from the address comparator) in the serial operating mode register is tested. If the bit is set to 1, it is determined that normal sending has been performed; if 0, it is determined that a send error has occurred. ### 5.6.7 SCK pin output handling The SCK/P01 pin, which incorporates an output latch, can also produce static output by software control in addition to a normal serial clock. The number of SCKs can be set as desired by using software to control the P01 output latch (the SO/SB0, and SI/SB1 pins are controlled by setting the RELT and CMDT bits). The SCK/P01 pin output control method is described below: - (1) The serial operation mode register (CSIM) is set (SCK pin: Output mode, serial operation: Enabled). SCK is set to 1 when serial transfer stops. - (2) The P01 output latch is controlled by using bit manipulation (operation) instructions. Example: To output one clock pulse of SCK by using software. SEL MB15 ; or CLR1 MBE MOV XA, #10000011B ; SCK ( $f_x/2^3$ ), output mode MOV CSIM, XA SET1 0FF0H.1 ; SCK/P01 − 1 Fig. 5.6-17 SCK/P01 Pin Configuration The P01 output latch is mapped in address FF0H bit 1. When the RESET signal is generated, the P01 output latch is set to 1. #### Cautions: - 1. The P01 output latch must be set to 1 during normal serial transfer. - 2. Do not use "PORT0.1" to specify the P01 output latch address. Write directly the address (FF0H.1) in operand. At that time, set MBE to 0, or set MBE to 1 and MBS to 15. ### 5.6.8 Serial interface application The serial interface for each mode is explained using examples of applications. The normal serial interface communication sequence is as follows: - 1) Set transfer mode. (Set data in CSIM.) - 2) Write data into SIO and give transfer start indication. (MOV SIO, XA or XCH XA, SIO. At that time, automatic transfer start indication is given.) - 3) After checking that the serial interrupt routine or interrupt request flag (IRQCSI) is set, read receive data, and start transfer. - The SBI mode communication sequence is explained in detail in (3) below. - (1) 3-line serial I/O mode - (a) To transfer data starting at MBS using transfer clock of 262 kHz (at 4.19 MHz) (master operation). Example: CLR1 MBE MOV XA, #10000010B MOV CSIM, XA ; Transfer mode is set. MOV XA, TDATA ; TDATA is the transfer data storage address. MOV SIO, XA ; Transfer data is set. : Transfer is started. ### Caution: At the second time or after, transfer can be started by setting data in SIO (MOV SIO, XA or XCH XA, SIO). In this application example, the $\mu PD75328$ SI/SB1 pin can be used for input. (b) To transfer data starting at the LSB using external clock (slave operation). (In this example, the shift register read/write function to invert the LSB and MSB is used effectively.) Example: Main routine CLR1 MBE MOV XA, #84H MOV CSIM. XA ; Serial operation stop, LSB/MSB inversion mode, external clock MOV XA, TDATA MOV SIO, XA MOV SIO, XA ; Transfer data is set. : Transfer is started. EI IECSI ΕI Interrupt routine (MBE = 0) MOV XA. TDATA XCH XA, SIO ; Receive data - send data, transfer start MOV RDATA, XA ; Receive data is saved. RETI (c) To transfer data at a high speed using a transfer clock of 524 kHz (at 4.19 MHz). Example (master) CLR1 MBE MOV XA, #10000011B MOV CSIM, XA ; Transfer mode is set. MOV XA, TDATA MOV SIO, XA ; Transfer data is set, Transfer is started. LOOP: SKTCLR IRQCSI ; IRQCSI is tested. BR LOOP MOV XA. SIO : Receive data is read. ### (2) 2-line serial I/O mode The serial bus is formed and a number of devices are connected. ### Example: The example system consists of the $\mu$ PD75328 as the master and $\mu$ PD75104, $\mu$ PD7519H, and $\mu$ PD7225G connected as slaves. To form a serial bus as in this example, FFH is previously written into the shift register, a high level is output to the shift register, a high level is output to the SO pin, the output buffers are turned off, and the bus is released except when the SI and SO pins are connected for serial data output. Since the µPD7519H SO pin cannot be placed in the high impedance state, a transistor is connected for open collector output, as shown in the diagram above. At the time of data input, the transistor is turned off by previously writing 00H into the shift register. The data output timing by the microcomputers is predetermined. The serial clock is output by the master microcomputer µPD75328; all other slave microcomputers operate on external clocks. # (3) SBI mode An application example of serial data communication in the SBI mode is given. In the example, the $\mu$ PD75328 can operate as a master or a slave CPU. The master can also be changed by using a command. ### (a) Serial bus configuration The serial bus configuration in the application example given here assumes that the µPD75328 is connected to bus lines as one device in the serial bus. The following two μPD75328 pins are used: Serial data bus SB0 (P02/SO) and serial clock SCK (P01). Fig. 5.6-18 shows an example of a serial bus configuration Fig. 5.6-18 Serial Bus Configuration Example # (b) Command explanation Command types The application example uses the following commands: 1) READ Data is transferred from slave to master. 2) WRITE: Data is transferred from master to slave. 3) END: WRITE command completion is reported to slave. 4) STOP: WRITE command stop is reported to slave. 5) STATUS: The slave state is read. 6) RESET: The current slave being selected is made unselected. 7) CHGMST: The master authorization is transferred to the slave. #### Communication sequence - The communication sequence between the master and slave is as follows: - 1) Communication is started by the master, which sends the address of the slave to communicate with and selects the slave (chip select). - The slave which receives the address returns $\overline{ACK}$ and communicates with the master. (The slave is placed in selected state.) - 2) Command and data are transferred between the slave selected in 1 and the master. Since command and data are transferred point-to-point (between the master and specific slave), other slaves must be deselected. - 3) Communication terminates when the slave is deselected in either of the following cases: - When the master sends the RESET command, the selected slave is deselected. - If the master is changed by using the CHGMST command, the device changed from master to slave is deselected. Command format - The command transfer formats are shown below: - 1) READ command The READ command reads data from a given slave. The read data count ranges from one to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave Fig. 5.6-19 READ Command Transfer Format After receiving the data count, the slave returns $\overline{ACK}$ if the number of $\underline{data}$ bytes that can be sent is greater than the data count. If it is less than the data count, the slave does not return $\overline{ACK}$ , resulting in an error. During data transfer, the slave compares the SIO contents before and after data transfer to check that data has been output to the bus normally. If the SIO contents before and after transfer do not match, the slave does not return $\overline{ACK}$ , resulting in an error. 2) WRITE, END, and STOP commands The WRITE, END, and STOP commands are used to write data into a particulary slave. The write data count ranges from 1 to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave # Fig. 5.6-20 WRITE, END Command Transfer Format After receiving the data count, the slave returns $\overline{ACK}$ if the receive data store area is larger than the data count. If it is less than the data count, it does not return $\overline{ACK}$ , resulting in an error. At the termination of all data transfer, the master sends the END command to the slave. It signals that all data has been transferred normally. The slave also receives an END command before it completes all data reception. In this case, the data which has been received immediately before the END command is received becomes valid. During data sending, the master compares the SIO contents before and after data sending to check that data has been output to the bus normally. If the SO contents before and after sending do not match, the master sends the STOP command and stops data transfer. M: Output by master S: Output by slave Fig. 5.6-21 STOP Command Transfer Format When receiving the STOP command, the slave invalidates the 1-byte data received immediately before receiving the STOP command. 3) STATUS command The STATUS Command Transfer Format - M: Output by master - S: Output by slave Fig. 5.6-22 STATUS Command Status Format Fig. 5.6-23 shows the format of the status returned by the slave. Fig. 5.6-23 STATUS Command Status Format To send status data, the slave compares the contents before and after sending status data. If they do not match, the slave does not return ACK, resulting in an error. ### 4) RESET command The RESET command is used to cause the currently selected slave to be selected. When the RESET command is issued, all slaves can be deselected. - M: Output by master - S: Output ba slave Fig. 5.6-24 RESET Command Transfer Format ### 5) CHGMST command The CHGMST command transfers the master authorization to the currently selected slave. - M: Output by master - S: Output by slave Fig. 5.6-25 CHGMST Command Transfer Format When receiving the CHGMST command, the slave decides whether or not it can receive the master authorization, and returns either of the following data to the master: - OFFH: Master change is enabled. - 00H : Master change is disabled. When transferring data, the slave compares the SIO contents before and after data transfer. If they do not match, the slave does not return $\overline{ACK}$ , resulting in an error. If no error occurs, the master serves as a slave after 0FFH data sending is complete. If no error occurs, the slave serves as the master after 0FFH data sending is completed. ### Error occurrence When a communication error occurs, the master and slave operate as explained below: The slave informs the master of error occurrence by returning no ACK. When an error occurs, the status bit (bit 2) indicating error occurence is set to 1 and all command processing being performed is cancelled.\_\_\_\_ After completing the sending or receiving of one byte, the master checks whether or not $\overline{ACK}$ is returned from slave. If $\overline{ACK}$ is not returned from slave within a given period after sending or receiving is completed, the master decides that an error has occurred and outputs a dummy $\overline{ACK}$ signal. Fig. 5.6-26 Master and Slave Operation when Error Occured The following errors are possible: - Errors that may occur in the slave - 1) Command transfer format is erroneous. - 2) Undefined command is received. - 3) The number of data bytes to be transferred (data count) is insufficient during READ command execution, - 4) Data storage area is insufficient during WRITE command execution. - 5) When READ, STATUS, or CHGMST command data is sent, data changes. When any error in 1) or 5) occurs, no ACK is returned. - Errors that may occur in the master When WRITE command data is sent, if data changes, STOP command is sent to the slave. #### 5.7 LCD Controller/Driver 5.7.1 LCD controller/driver configuration The $\mu PD75328$ incorporates a display controller which generates segment and common signals according to the display data memory contents and incorporates segment and common drivers which can drive the panel directly. Fig. 5.7-1 shows the LCD controller/driver configuration. Fig. 5.7-1 LCD Controller/Driver Block Diagram ### 5.7.2 LCD controller/driver functions The µPD75328 LCD controller/driver functions are as follows: - (a) Display data memory is read automatically by DMA operation and segment and common signals are generated. - (b) Display mode can be selected from among the following five. - 1) Static - 2) 1/2 duty (1/2 bias) - 3) 1/3 duty (1/2 bias) - 4) 1/3 duty (1/3 bias) - 5) 1/4 duty (1/3 bias) - (c) A frame frequency can be selected from among four in each display mode. - (d) A maximum of 20 segment signal output pins (S12-S31) and four common signal output pins (COM0 COM3). - (e) The segment signal output pins (S24-S27 and S28-S31) can be changed to the output ports (BP0-BP3 and BP4-BP7) in 4-pin units. - (f) Split-resistor can be incorporated to supply LCD drive power. (Mask option) - Various bias laws and LCD drive voltage can be handled. - When display is off, current flow to the split resistor is cut. - (g) Display data memory not used for display can be used for normal data memory. - (h) It can also operate by using the subsystem clock. Table 5.7-1 lists the maximum number of picture elements that can be displayed in each display mode. Table 5.7-1 Maximum Number of Displayed Picture Elements | Bias law | Time division | Used COMMON signals | Maximum number of picture elements | | |----------|-----------------------------------------------------|---------------------|----------------------------------------|--| | _ | Static COM0 (COM1, 2, 3) 20 (segment 20 x common 1) | | 20 (segment 20 x common 1) (Note 1) | | | 1/2 | 2 | COM0, 1 | 40 (segment 20 x common 2) (Note 2) | | | | 3 | COM0 1 0 | 60 (accompant 60 v. common 3) (Nate 3) | | | 1/3 | 3 | COM0, 1, 2 | 60 (segment 20 x common 3) (Note 3) | | | | 4 | COM0, 1, 2, 3 | 80 (segment 20 x common 4) (Note 4) | | Note 1: 2 digits (eight segment signal/digit) on LCD panel (8. display). Note 2: 5 digits (four segment signal/digit) on LCD panel ( $\hat{\boldsymbol{\theta}}$ . display). Note 3: 6 digits (three segment signal/digit) on LCD panel (8. display). Note 4: 10 digits (two segment signal/digit) on LCD panel (B. display). #### 5.7.3 Display mode register The display mode register (LCDM) consists of eight bits to specify the display mode, LCD clock, frame frequency, segment or bit port output, and display output on/off control. LCDM is set by using 8-bit memory operation instruction. Only bit 3 (LCDM3) can be set and cleared by using bit operation (manipulation) instructions. When the RESET signal is generated, all the LCDM bits are cleared. | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | |---------|-------|-------|-------|-------|-------|-------|-------|-------|--------| | F8CH | LCDM7 | LCDM6 | LCDM5 | LCDM4 | LCDM3 | LCDM2 | LCDM1 | LCDM0 | LCDM | Display Mode Selection | LCDM3 | LCDM2 | LCDM1 | LCDM0 | Time division value | Bias method | |-------|------------|-----------|----------|---------------------|-------------| | 0 | Х | Х | X | Display off | (Note) | | 1 | 0 | 0 | 0 | 4 | 1/3 | | 1 | 0 | 0 | 1 | 3 | 1/3 | | 1 | 0 | 1 | 0 | 2 | 1/2 | | 1 | 0 | 1 | 1 | 3 | 1/2 | | 1 | 1 1 0 0 | | | Static | | | | Other than | the above | Undefine | ed | | Note: All segment signals are unselected. ### LCD Clock Selection | LCDM5 | LCDM4 | LCDMCL | |-------|-------|-----------------------------------------| | 0 | 0 | f <sub>W</sub> /2 <sup>9</sup> (64 Hz) | | 0 | 1 | f <sub>W</sub> /2 <sup>8</sup> (128 Hz) | | 1 | 0 | f <sub>W</sub> /2 <sup>7</sup> (256 Hz) | | 1 | 1 | f <sub>W</sub> /2 <sup>6</sup> (512 Hz) | Caution: LCDCL is supplied only when the watch timer operates. To use the LCD controller, bit 2 of watch mode register WM should be set to 1. Segment and Bit Port Output Change Specification | LCDM7 | LCDM6 | S24/S27 | S28/S31 | Number of segment output pins | Number of bit port output pins | |-------|-------|-----------------|-----------------|-------------------------------|--------------------------------| | 0 | 0 | Segment output | Segment output | 20 | 0 | | 0 | 1 | Segment output | Bit port output | 16 | 4 | | 1 | 0 | Bit port output | Segment output | 16 | 4 | | 1 | 1 | Bit port output | Bit port output | 12 | 8 | # Frame Frequency (Hz) | tame requests (riz) | | | | | | |--------------------------------|----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|--| | LCDCL<br>Display<br>duty cycle | f <sub>W</sub> /2 <sup>9</sup> (64 Hz) | f <sub>W</sub> /2 <sup>8</sup> (128 Hz) | f <sub>W</sub> /2 <sup>7</sup> (256 Hz) | f <sub>W</sub> /2 <sup>6</sup> (512 Hz) | | | Static | 64 | 128 | 256 | 512 | | | 1/2 | 32 | 64 | 128 | 256 | | | 1/3 | 21 | 43 | 85 | 171 | | | 1/4 | 16 | 32 | 64 | 128 | | When $f_w = 32.768 \text{ kHz}$ $f_w$ : Input clock to watch timer ( $f_x/128$ or $f_{xT}$ ) Fig. 5.7-2 Display Mode Register Format # 5.7.4 Display control register The display control register controls LCD drive as follows: - Enables or disables common and segment output. - Cuts current flow to the split resistor for the LCD power supply. - Enables or disables output of the synchronizing clock (LCDCL) and synchronizing signal (SYNC) to the controller/driver for external segment signal extension. LCDCL is set by using a 4-bit memory operation instruction. When the RESET signal is generated, the display control register is cleared. | Address | | | | | Symbol | |---------|---|-------|---|-------|--------| | · | 3 | 2 | 1 | 0 | | | F8EH | 0 | LCDC2 | 0 | LCDC0 | LCDC | | LCDC0 | 0 | 1 | | | |--------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--| | LCDM3 X | | 0 | <b>1</b> | | | COM0-3 | Low level is output (display off). | Common signal corresponding to the display mode is output. | Common signal corresponding to the display mode is output. | | | S12-S23 | Low level is output | Segment signal corresponding to the | Segment signal corresponding to the display mode is output (display on). | | | S24-S31 segment specification pins | (display off). | display mode is output (no-selection level output, display off). | | | | S24-S31 bit port specification pins | Bit 0 for the corres-<br>ponding display<br>data memory is<br>output (bit port<br>function). | Bit 0 for the corresponding display data memory is output (bit port function). | Bit 0 for the corresponding display data memory is output (bit port function). | | | Power supply to<br>split resistor<br>(BIAS pin output) | Off<br>(high impedance) | On<br>(high level) | On<br>(high level) | | Note 1: ( ): When internal split register for LCD drive power supply is not contained. LCDCL and SYNC Signal Output Enable/Disable Specification Bit | LCDCL2 | 0 | LCDCL | and SYNC signal output is disabled. | |--------|---|-------|-------------------------------------| | LUDULZ | 1 | LCDCL | and SYNC signal output is enabled. | Note: LCDCL, SYNC signal output are provided for future system extension. Disable signal output at present. Fig. 5.7-3 Display Control Register Format ### 5.7.5 Display data memory The display data memory is mapped in 1ECH-1FFH. The display data memory is an area read by the LCD controller/driver, which performs DMA operation independently of CPU operation. The LCD controller controls the segment signals according to data in the display data memory. When S24-S31 are used for bit ports, bit 0 of the data written into display data memory addresses 1F8H-1FH is output from each bit port output pin. The area not used for LCD display or ports can be used for normal data memory. The display data memory is handled in 1- or 4-bit units. It cannot be handled in 8-bit units. Fig. 5.7-5 shows the relationship between the display data memory bits and segment output/bit port output. Fig. 5.7-4 Data Memory Map Fig. 5.7-5 Relationship between Display Data Memory and Common Segment # 5.7.6 Common and segment signals Each picture element of the LCD panel goes on when the potential difference between its corresponding common signal and segment signal reaches or exceeds a given voltage (LCD drive voltage VLCD). It goes off when the potential difference falls below VLCD or reaches 0V. Since deterioration occurs when DC potential is maintained as the common and segment signals, the LCD panel is driven by AC. ### (1) Common signals The common signals become the selection timing in the order listed in Table 5.7-2 according to the set time division number, and repetitive operation is performed by using them as one period. In the static mode, COM0 to COM3 output the same signal. In division by 2, neither COM2 nor COM3 pin should be connected. In division by 3, do not connect the COM3 pin. Table 5.7-2 COM Signals | COM signal Time division number | СОМО | СОМ1 | COM2 | СОМЗ | |---------------------------------|------|------|------------------------|------------------------| | Static | | | | | | 2 | | | No connection required | No connection required | | 3 | | | | No connection required | | 4 | | | | | ### (2) Segment signals There are 20 segment signals corresponding to 20 locations of the display data area (1ECH-1FFH) of the data memory. Bits 0 to 3 of each location are automatically read in synchronization with the selection timing for COM0 to COM3 respectively. If the bit is set to 1, it produces the segment selection voltage; if 0, the bit produces the no-selection voltage output from the corresponding segment pin (512-S31). Thus, check the display patterns formed according to the combinations of the LCD panel front electrode (corresponding to segment signal) and rear electrode (corresponding to common signal). Then, on a one-to-one basis, write into the display area the bit data which corresponds to the pattern to be displayed. Display data area bits 1 to 3 in the static mode, bits 2 and 3 in the division by 2 mode, and bit 3 in the division by 3 mode are not accessed and can be used for purposes other than display. ### (3) Common and segment signal output waveforms Tables 5.7-3 to 5.7-5 list voltages output to the common and segment signals. +VLCD/-VLCD on voltage is applied only when both signals become selection voltages; otherwise, the off voltage is applied. Table 5.7-3 LCD Drive Voltage (Static) | Segment signal | Selection | No-selection | |-----------------------------------|--------------------------------------|-----------------------------------| | Common signal | V <sub>LC0</sub> /V <sub>ss</sub> | V <sub>ss</sub> /V <sub>LC0</sub> | | V <sub>SS</sub> /V <sub>LC0</sub> | +V <sub>LCD</sub> /-V <sub>LCD</sub> | 0V/0V | Table 5.7-4 LCD Drive Voltage (1/2 Bias Law) | Se | gment signal | Selection | No-selection | | |--------------------|-------------------------------------|----------------------------------------------|----------------------------------------------|--| | Common signal COMm | | V <sub>LC0</sub> /V <sub>SS</sub> | V <sub>SS</sub> /V <sub>LC0</sub> | | | Selection | V <sub>SS</sub> /V <sub>LC0</sub> | +V <sub>LCD</sub> /-V <sub>LCD</sub> | 0V/0V | | | No-selection | V <sub>LC1</sub> = V <sub>LC2</sub> | +1/2 V <sub>LCD</sub> /-1/2 V <sub>LCD</sub> | -1/2 V <sub>LCD</sub> /+1/2 V <sub>LCD</sub> | | Table 5.7-5 LCD Drive Voltage (1/3 Bias Law) | Se | gment signal | Selection | No-selection | | |--------------------|------------------------------------|----------------------------------------------|----------------------------------------------|--| | Common signal COMm | | V <sub>LC0</sub> /V <sub>SS</sub> | V <sub>LC2</sub> /V <sub>LC1</sub> | | | Selection | V <sub>SS</sub> /V <sub>LC0</sub> | +V <sub>LCD</sub> /-V <sub>LCD</sub> | +1/3 V <sub>LCD</sub> /-1/3 V <sub>LCD</sub> | | | No-selection | V <sub>LC1</sub> /V <sub>LC2</sub> | +1/3 V <sub>LCD</sub> /-1/3 V <sub>LCD</sub> | +1/3 V <sub>LCD</sub> /-1/3 V <sub>LCD</sub> | | Figs. 5.7-6 to 5.7-8 shows the common signal waveforms. Fig. 5.7-9 shows the common and segment signal voltages and phases. Fig. 5.7-7 Common Signal Waveform (1/2 Bias Law) Fig. 5.7-8 Common Signal Waveform (1/3 Bias Law) Fig. 5.7-9 Common and Segment Signal Voltages and Phases Fig. 5.7-9 Common and Segment Signal Voltages and Phases (cont'd) 5.7.7 Supply of LCD drive power $V_{LCI}$ , $V_{LCI}$ , and $V_{LC2}$ in the $\mu$ PD75328, a split resistor can be incorporated in the $V_{LCI}$ - $V_{LC2}$ pins for the LCD drive power supply. According to the bias law, the LCD drive power can be supplied without an external split resistor. The $\mu$ PD75328 also includes the BIAS pin to deal with various LCD drive voltages. The BIAS and $V_{\text{LC0}}$ pins are connected externally. Table 5.7-6 lists proper LCD drive power supply values based on the static, 1/2, and 1/3 bias laws. Table 5.7-6 LCD Drive Power Supply Values | LCD<br>drive power | No bias<br>(static mode) | 1/2 | 1/3 | |--------------------|--------------------------|-------------------------------|----------------------| | V <sub>LC0</sub> | V <sub>LCD</sub> | V <sub>LCD</sub> | V <sub>LCD</sub> | | V <sub>LC1</sub> | 2/3 V <sub>LCD</sub> | 1/0 \/ (Note 1) | 2/3 V <sub>LCD</sub> | | V <sub>LC2</sub> | 1/3 V <sub>LCD</sub> | 1/2 V <sub>LCD</sub> (Note 1) | 1/3 V <sub>LCD</sub> | | V <sub>LC3</sub> | 0V | 0V | 0V | Note 1: When 1/2 bias is used, the VLC1 and VLC2 pins must be connected externally. Note 2: When the BIAS and $V_{LC0}$ pins are not connected, $V_{LC0} = 3/5 V_{DD}$ (when split resistor is incorporated). When the BIAS and $V_{1CD}$ pins are connected, $V_{1CD} = V_{DD}$ In Fig. 5.7-10, (a) to (c) show LCD drive power supply examples according to Table 5.7-6. Fig. 5.7-11 (d) shows an example in which external resistor is connected to the LCD drive voltage pins (V<sub>I CO</sub>-V<sub>I CO</sub>) and BIAS pin, and internal split resistor is fineadjusted. Current flow through the split resistor can also be cut by clearing display control register bit 0 (LCDC0). This LCD power on/off control is also useful to prevent DC voltage from being applied to LCD when the LCD clock is stopped by execution of a STOP instruction and when the watch timer operates using the main system clock. That is, display control register bit 0 (LCDC0) is cleared and all LCD drive power sources are placed in the same potential VSS immediatly before the STOP instruction is executed, thereby suppressing the potential difference between the LCD electrodes even if the LCD clock is stopped. When the watch timer operates using the subsystem clock, the LCD display can still be used. (a) 1/3 bias law and static mode display (b) 1/2 bias law (c) 1/3 bias law and static display mode In example (a), $V_{DD}$ = 5V and LCD drive voltage $V_{LCD}$ = 3V. In example (b), $V_{DD}$ = 5V and $V_{LCD}$ = 2,5V. In example (c), $V_{DD}$ = 5V and $V_{LCD}$ = 5V. Fig. 5.7-10 LCD Drive Power Connection Examples (when split resistor is incorporated) # (b) Static display mode (c) 1/2 bias method (d) 1/3 bias method In example (a), $V_{DD}$ = 5V and LCD drive voltage $V_{LCD}$ = 5V. In example (b) and (d), $V_{DD}$ = 5V and LCD drive voltage $V_{LCD}$ = 3V. In example (c), $V_{DD}$ = 5V and $V_{LCD}$ = 2.5V. Note: Be sure to set LCDC0 to 1 (also during the standby mode) Fig. 5.7-11 LCD Drive Power Connection Examples (when split resistor is corporated externally) ### 5.7.8 Display mode ### (1) Static display example Fig. 5.7-14 shows connection of a static 3-digit LCD panel having the display pattern shown in Fig. 5.7-13, the $\mu$ PD75328 segment signals (S12-S31), and the common signal (COM0). In this example, 123 is displayed. The contents of the display data memory (addresses 1ECH-1FFH) correspond to the display pattern. Here, 3 ( $\exists$ ) at the third digit position is taken as an example. It is necessary to output selection and no-selection voltages as shown in Fig. 5.7-12 to the S12-S18 pins at the COM0 common signal timing according to the display pattern shown in Fig. 5.7-13. | Segment<br>Common | S12 | S13 | S14 | S15 | S16 | S17 | S18 | |-------------------|-----------|-----------|-----------|--------------|-----------|--------------|-----------| | COM0 | Selection | Selection | Selection | No-selection | Selection | No-selection | Selection | Fig. 5.7-12 Selection/Non-selection Voltages of S12-S18 Pins (Static Display Examples) This shows that the bit 0 string of display data memory addresses 1ECH-1EFH corresponding to S12-S18 needs to be set to 1110101. Fig. 5.7-15 shows the S14, S15, and COM0 LCD drive waveforms. This shows that alternating current square wave of +V<sub>LCD</sub>/ –V<sub>LCD</sub> that is LCD on level is generated when S14 becomes the selection voltage at the selection timing of COM0. Since the same waveform as COM0 is output to COM1 to COM3, the drive capability can be increased by connecting COM0, COM1, COM2, and COM3. Fig. 5.7-13 Static Mode LCD Display Pattern and Electrode Connection Fig. 5.7-14 Static LCD panel Connection Example Fig. 5.7-15 Static LCD Drive Waveform Example (2) Division by 2 display example Fig. 5.7-18 shows connection of the division by 2 mode 5-digit LCD panel having the display pattern shown in Fig. 5.7-17, the $\mu$ PD75328 segment signals (S12-S31), and the common signals (COM0 and COM1). In the example, 123.45 is displayed. The contents of the display data memory (addresses 1ECH-1FFH) correspond to the display pattern. Here, 3. (3.) at the third digit position is taken as an example. It is necessary to output the selection and no-selection voltages as shown in Fig. 5.7-16 to the S20-23 pins at the timing of the COM0 and COM1 common signal according to the display pattern shown in Fig. 5.7-17. | Segment | S20 | S21 | S22 | S23 | |---------|-----------|-----------|--------------|--------------| | COM0 | Selection | Selection | No-selection | No-selection | | COM1 | Selection | Selection | Selection | Selection | Fig. 5.7-16 Selection/Non-selection Voltages of S8-S11 Pins (Division by 2 Mode Display Examples) This shows that for example, the display data memory address 1F7H bits corresponding to S23 need to be set to $\times \times 10$ . Fig. 5.7-19 shows an LCD drive waveform example among S23 and common signals. This shows an alternating current square wave of $+V_{LCD}/-V_{LCD}$ that is the LCD on level being generated when S23 is the selection voltage at the COM1 selection timing. Fig. 5.7-17 Division by 2 Mode LCD Display Pattern and Electrode Connection Fig. 5.7-18 Division by 2 LCD Panel Connection Example Fig. 5.7-19 Division by 2 LCD Drive Waveform Example (1/2 Bias Law) ### (3) Division by 3 display example Fig. 5.7-22 shows connection of a division by 3 mode 6-digit LCD panel having the display pattern shown in Fig. 5.7-21, the $\mu$ PD75328 segment signals (S12-S29), and the common signals (COM0-COM2). In this example, 12345.6 is displayed. The contents of the display data memory (addresses 1ECH-1FDH) correspond to the display pattern. Here, 5. (5.) at the second-digit position is taken as an example. It is necessary to output the selection and no-selection voltages as shown in Fig. 5.7-20 to the S15-S17 pins at the COM0-COM2 common signal timings according to the display pattern shown in Fig. 5.7-21. | Segment | S15 | S16 | S17 | |---------|--------------|-----------|--------------| | СОМО | No-selection | Selection | Selection | | COM1 | Selection | Selection | No-selection | | COM2 | Selection | Selection | - | Fig. 5.7-20 Selection/Non-selection Voltages of S15-S17 Pins (Division by 3 Mode Display Examples) This shows that the bits at display data memory address 1EFH corresponding to S15 need to be set to x110. Fig. 5.7-23 and 5.7-24 show LCD drive waveforms among S15 and common signals (1/2 and 1/3 bias law). These shown an alternating current square wave of $+V_{LCD}/-V_{LCD}$ that is the selection voltage at the COM1 selection timing and S15 is the selection voltage at the COM2 selection timing. Fig. 5.7-21 Division by 3 Mode LCD Display Pattern and Electrode Connection Fig. 5.7-22 Division by 3 LCD Panel Connection Example Fig.5.7-23 Division by 3 LCD Drive Waveform Example (1/2 Bias Law) Fig.5.7-23 Division by 3 LCD Drive Waveform Example (1/3 Bias Law) (4) Division by 4 Display Example Fig. 5.7-27 shows connection of the division by 4 mode 10-digit LCD panel having the display pattern shown in Fig. 5.7-26, the $\mu$ PD75328 segment signals (S12-S31), and the common signals (COM0-COM3). In this example, 123456.7890 is displayed. The contents of the display data memory (addresses 1ECH-1FFH) correspond to the display pattern. Here, 6. ( $\mathcal{B}$ .) at the 5-digit position is taken as an example. It is necessary to output the selection and no-selection voltages as shown in Fig. 5.7-25 to the S20 and S21 pins at the COM0-COM3 common signal timing according to the display pattern shown in Fig. 5.7-26. | Segment | S20 | S21 | |---------|--------------|-----------| | COM0 | Selection | Selection | | COM1 | No-selection | Selection | | COM2 | Selection | Selection | | сомз | Selection | Selection | Fig. 5.7-25 Selection/Non-selection Voltage of S20 and S21 (Division by 4 Mode Display Examples) This shows that the bits at display data memory address 1F4H corresponding to S20 need to be set to 1101. Fig. 5.7-28 shows LCD drive waveforms for S20, COM0, and COM1 signals. (Waveforms for COM2 and COM3 are omitted because of drawing space.) This shows an alternating current square wave of +V<sub>LCD</sub>/-V<sub>LCD</sub> that is the LCD on level being generated when S20 becomes the selection voltage at the COM0 selection timing. Fig. 5.7-26 Division by 4 Mode LCD Display Pattern and Electrode Connection Fig. 5.7-27 Division by 4 LCD Panel Connection Example Fig. 5.7-28 Division by 4 LCD Drive Waveform Example (1/3 Bias Method) #### 5.8 A/D Converter The µPD75328 contains an internal analog/digital (A/D) converter of 8-bit precision having six channels of analog input (AN0-AN5). The A/D converter adopts the successive comparison method. #### 5.8.1 A/D converter configuration Figure 5.8.1 shows the A/D converter configuration. Fig. 5.8.1 A/D Converter Block Diagram ### (1) A/D converter pins #### (a) AN0-AN5 AN0-AN5 are 6-channel analog signal input pins to the A/D converter. Analog signals to be converted into digital form are input. The A/D converter contains a sample hold circuit which holds the analog input voltage during the A/D conversion. Caution: Use the ANO-AN5 input voltage within the prescribed limits. If particulary a voltage more than V<sub>DD</sub>, less than V<sub>SS</sub> (even if the voltage is within the maximum absolute limits) is input, the channel conversion value becomes undefined and other channel conversion values may also be adversely affected. # (b) A/D conversion mode register The A/D conversion mode register (ADM) is an 8-bit register which selects an analog input channel, indicates conversion start, and detects the conversion termination. ADM is set by using an 8-bit handling instruction. Bit 2 (EOC) and bit 3 (SOC) can be handled bitwise. When the RESET signal is generated, ADM is initialized to 04H (only EOC is set to 1 and other bits are cleared). Caution: A/D conversion starts at the maximum $2^4/f_{\chi}$ second delay (3.81 $\mu s$ when the clock is 4.19 MHz) after SOC is set. (See 5.8.2) Fig. 5.8.2 A/D Conversion Mode Register Format (2) SA register (successive approximation register) The SA register is an 8-bit register which stores the A/D conversion results. The SA register is read by using an 8-bit handling instruction. It is a read-only register; write operation or bit handling can not be performed on the register. When the RESET signal is generated, the SA register is initialized to 7FH. Caution: When A/D conversion is started by setting ADM register bit 3 (SOC) to 1, the conversion results in the SA register are destroyed and the SA register becomes undefined until new conversion results are stored. Note: If the A/D converter reference voltage (AV<sub>REF</sub>) is 0.65 V<sub>DD</sub> or less, the conversion precision may lower. To correct it, comparator bias voltage selection is made. #### 5.8.2 A/D converter operation Analog input signal to be converted into digital form is specified by setting A/D conversion mode register bits 6 to 4 (ADM6-ADM4). A/D conversion is started by setting A/D bit 3 (SOC) to 1. SOC is automatically cleared after it is set. A/D conversion is made by the successive comparison method by using hardware. The 8-bit data resulting from the conversion is stored in the SA register. When the conversion terminates, ADM bit 2 (EOC) is set to 1. Fig. 5.8-3 shows the A/D conversion timing chart. The use of the A/D converter is as follows: ① Select an analog input channel. (Set ADM6-ADM4.) 2 Indicate A/D conversion start. (Set SOC.) Wait for the A/D conversion termination. (Wait for EOC to be set or wait with software timer.) 4 Read the A/D conversion results. (Read the SA register.) Caution 1: ① and ② can also be performed at the same time. Caution 2: After SOC is set, the maximum 2<sup>4</sup>/t<sub>x</sub> second delay (3.81 µs when the clock is 4.19 MHz) is made from A/D conversion start to EOC clear. Test EOC in the time listed in Table 5.8-1 after SOC is set. Table 5.8-1 also lists the A/D conversion time. Table 5.8-1 Setting of SCC and PCC | SCC, PCC setup value | | lue | A/D conversion time | Wait time until EOC | Wait time until the A/D conversion termination | | |----------------------|------|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------| | SCC3 | SCC0 | PCC1 | PCC0 | A/D conversion time | test after SOC is set | after SOC is set. | | | | 0 | 0 | | Wait not required | 3 machine cycles | | 0 | 0 | 1 | 0 | 2 <sup>4</sup> /f <sub>y</sub> x 9 (34.3 μs/f <sub>y</sub> = 4.19 MHz) | 2 machine cycles | 20 machine cycles | | | | 1 | 1 | $\frac{2}{10}$ $\frac{1}{10}$ | 4 machine cycles | 40 machine cycles | | 0 | 1 | Х | Х | | Wait not required | Wait not required | | 1 | Х | Х | Х | Conversion operation stop | - | | X: don't care Fig. 5.8-3 A/D Conversion Timing Chart Fig. 5.8-4 Relationchip Between Analog Input Voltage and A/D Conversion Results (ideal instance) ### 5.8.3 Caution during standby mode The A/D converter operates on the main system clock. Thus, operation stops in the STOP mode or the HALT mode (subsystem clock). Since current also flows into the AV $_{\rm REF}$ pin at the time, the current must be cut to reduce the entire system power consumption. The P83 pin which has the drive capability higher than other port pins can directly supply voltage to the AV $_{\rm REF}$ pin. (See Fig. 5.8-5.) In this case, however, there is no precision in the actual AV $_{\rm REF}$ voltage, thus the conversion value itself has no precision and can only be used for relative comparison. If a low level is output to the P83 pin during the standby mode, power consumption can be lessened. The P83 pin of peripheral hardware emulator $\mu$ PD75390 used during emulation using an evaluation kit has the same drive capability as other port pins. Thus, if an example shown in Fig. 5.8-5 is used, AV<sub>REF</sub> during the emulation is lower than AV<sub>REF</sub> when the $\mu$ PD75328 is used actually, and the A/D conversion values are not made equal to each other. Fig. 5.8-5 Example of Reducting Method of Power Consumption during Standby Mode ### 5.8.4 A/D converter noise countermeasures To keep the 8-bit precision, the noise to AV<sub>REF</sub> and AN0-5 pins must be carefully avoided. The higher the output impedance in analog input is, as more effective it is. The noise countermeasures are made by setting C shown as Fig. 5.8-6. Remark: C = 100 $\sim$ 1000pF R = $\geq$ 5k $\Omega$ Fig. 5.8-6 Analog Input Pin Processing ### 5.9 Bit Sequential Buffer - 16 Bits The bit sequential buffer is a special data memory for bit manipulation. Bit manipulation can be easily performed by changing address and bit specification in sequence. The buffer is useful for bitwise processing of long data. The data memory consists of 16 bits. pmem.@L addressing of bit manipulation is enabled; indirect bit specification can be made by using the L register. Simply by incrementing or decrementing the L register in a program loop, processing can be performed while the specified bits are being moved in sequence. Fig. 5.9-1 Bit Sequential Buffer Format #### Remarks: In pmem.@L addressing, specified bits are moved according to the L register. Data can also be handled in direct addressing. The 1-, 4-, and 8-bit direct addressing modes and pmem.@L addressing mode can be used in combination for continuous input and output of 1-bit data. In 8-bit manipulation, BSB0 and BSB2 are specified, and data is handled every high-order eight and low-order eight bits. #### Example: To output 16-bit data in BUFF 1 and BUFF2 from port 3 bit 0 serially. CLR<sub>1</sub> MBE MOV XA. BUFF1 MOV BSB0, XA ; BSB0 and BSB1 are set. MOV XA, BUFF 2 MOV BSB2, XA ; BSB2 and BSB3 are set. MOV L. #0 LOOP: SKT BSB0. @L : BSB-specified bit is tested. LOOP1 BR NOP ; Dummy (timing adjustment) SET1 PORT3.0 : Port 3 bit 0 is set. BR LOOP2 LOOP1: CLR1 PORT3.0 ; Port 3 bit 0 is cleared. NOP ; Dummy (timing adjustment) NOP LOOP2: INCS : L- L+1 BR LOOP RET #### **CHAPTER 6 INTERRUPT FUNCTION** The µPD75328 contains six vectored interrupt sources and two testable inputs for versatile application. The μPD75328 interrupt control circuit has the following features to enable very high-speed interrupt service: - (a) Whether or not interrupts can be acknowledged can be controlled by using enable flag (IEXXX). - (b) The interrupt service start address and MBE during interrupt service can be set as desired by using a vector table. Starting the actual interrupt service program is fast. - (c) Interrupt request flag (IRQXXX) can be tested and cleared. Interrupt occurrence can be checked by using software. - (d) The standby mode (STOP or HALT) can be released by making an interrupt request. A backup release source is available by using the interrupt enable flag. ### 6.1 Interrupt Control Circuit Configuration Fig. 6.1-1 shows configuration of the interrupt control circuit. The hardware devices are mapped in data memory. Fig. 6.1-1 Interrupt Control Circuit Block Diagram II-4-138 ### 6.2 Interrupt Source Types and Vector Table Table 6.2-1 lists the types of interrupt sources for the μPD75328. Fig. 6.2-1 shows the interrupt vector table. **Table 6.2-1 Interrupt Source Types** | | Interrupt source | Internal<br>/external | Interrupt priority (Note 1) | Vectored interrupt request signal (vector table address) | |------------------------|--------------------------------------------------------------------------------------|-----------------------|------------------------------------------------|----------------------------------------------------------| | INTBT<br>(reference | time interval signal from basic interval timer) | Internal | 1 | VRQ1 (0002H) | | INT4<br>(both rising | and falling edge detection) | External | | | | INT0 | (selection of rising or falling edge detection) | External | 2 | VRQ2 (0004H) | | INT1 | | External | 3 | VRQ3 (0006H) | | INTCSI<br>(serial data | transfer end signal) | Internal | 4 | VRQ4 (0008H) | | | ce signal between programmable timer/<br>unt register and modulo register) | Internal | 5 | VRQ5 (000AH) | | | e detection of input to INT2 pin or falling edge<br>f any input to KR0-KR7) (Note 2) | External | Testable input signals (IRQ2 and IRQW are set) | | | INTW<br>(signal fron | n watch timer) | Internal | | | Note 1: The interrupt priority indicates the priority given to each interrupt when more than one interrupt request occurs at the same time. Note 2: For details of INT2, see 6.3 (2). #### Address | 002H | MBE | 0 | 0 | INTBT/INT4 start address (high-order five bits) | |------|-----|---|---|-------------------------------------------------| | | | | | INTBT/INT4 start address (low-order eight bits) | | 004H | MBE | 0 | 0 | INT0 start address<br>(high-order five bits) | | | | | | INT0 start address<br>(low-order eight bits) | | 006H | MBE | 0 | 0 | INT1 start address<br>(high-order five bits) | | | | | | INT1 start address<br>(low-order eight bits) | | H800 | MBE | 0 | 0 | INTCSI start address<br>(high-order five bits) | | | | | | INTCSI start address (low-order eight bits) | | 00AH | MBE | 0 | 0 | INTT0 start address<br>(high-order five bits) | | | | | | INTT0 start address<br>(low-order eight bits) | Fig. 6.2-1 Interrupt Vector Table µPD75328 The interrupt priority in Table 6.2-1 indicates the interrupt execution order when a number of interrupt requests occur at the same time or are held. The interrupt service start addresses and MBE setup values during interrupt service are written into the vector table. The vector table is set by using an assembler pseudo-instruction (VENTn). Example: To set INTBT/INT4 in vector table Caution 1: The vector table address specified in VENTn (n=1-5) becomes 2n address. Caution 2: Always set RBE to 0 in VENTn. Example: To set INTBT/INT4 and INTT0 in vector table. VENT1 MBE=0, RBE=0, GOTOBT VENT5 MBE=0, RBE=0, GOTOT0 #### 6.3 Hardware Devices of Interrupt Control Circuit (1) Interrupt request and enable flags The interrupt request flag (IRQXXX) is set to 1 when a given interrupt request occurs; it is automatically cleared when interrupt service is executed. Although IRQBT and INT4 share the vector address, they differ in clear operation. (See 6.6.) An interrupt enable flag (IEXXX) is provided for each interrupt request flag. An interrupt is enabled when the corresponding interrupt enable flag is set to 1 and disabled when the flag is set to 0. When the interrupt request flag is set, and the interrupt enable flag enables an interrupt, a vectored interrupt request (VRQn) occurs. This signal is also used to release the standby mode. The interrupt request and enable flags are handled by using the bit manipulation and 4-bit memory operation instructions. The flags can be directly handled by using the bit manipulation instruction regardless of how MBE is set. The interrupt enable flags are handled by using the EI IEXXX and DI IEXXX instructions. Normally, the interrupt request flags are tested by using the SKTCLR instruction. Example: EI IEO ; INT0 is enabled. DI IE1 : INT1 is disabled. SKTCLR IRQCSI : If IRQCSI is set to 1, skip and clear. If the interrupt request flag is set by using the instruction, a vectored interrupt is executed as if an interrupt occured although it did not actually occurs. When the RESET signal is generated, the interrupt request and enable flags are cleared, and all interrupts are disabled. Table 6.3-1 Interrupt Request and Enable Flags | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | IRQBT | Is set by reference time interval signal generated by the basic interval timer | IEBT | | IRQ4 | Is set when either the rising or falling edge of the INT4/P00 pin input signal is detected. | IE4 | | IRQ0 | Is set when the INT0/P10 pin input signal edge is detected. Detected edge is selected among rising and falling edges by using the INT0 mode register (IM0). | IE0 | | IRQ1 | Is set when the edge of the INT1/P11 pin input signal is detected. Detected edge is selected from rising and falling edges by using the INT1 mode register (IM1). | IE1 | | IRQCSI | Is set by serial data transfer end signal on serial interface. | IECSI | | IRQT0 | Is set by coincidence signal from timer/event counter 0. | IET0 | #### Table 6.3-1 Interrupt Request and Enable Flags (cont'd) | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | | | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|--| | IRQW | Is set by signal from the watch timer. | | | | | IRQ2 | Is set when the rising edge of the INT2/P12 pin input signal is detected or the falling edge of any input to the KR0/P60 to KR7/P73 pins is detected. | IE2 | | | ### (2) Noise eliminator and edge detection mode registers. Figs. 6.3-1 and 6.3-2 show the relationship of INTO and INT1, INT2 and KR0-KR7 pins, respectively, within the interrupt control circuit. They are used for inputting external interrupts in cases where noise can be eliminated by the sampling clock and the detected edge can be selected. Any pulse narrower than the sampling clock is determined to be a noise pulse and is eliminated by the noise eliminator. A pulse twice as wide (or more) as the sampling clock is acknowledged as a valid interrupt signal. For INTO the sampling clock can be changed to two stages. Note that when the INTO pin is used for P10 (port pin), the signal is also input via the noise eliminator. Caution: Since INT0 sampling uses clock, INT0 does not operate at standby mode. IRQ2 is set in either of the following modes: - (a) When the rising edge of INT2 pin input is detected, IRQ2 is set. - (b) When the falling edge of any input to KR0-KR7 pins is detected: When the falling edge of any input to pins selected among KR0-KR7 by using the edge detection mode register (IM2) is detected, IRQ2 is set. For example, if KR4-KR7 are selected, IRQ2 is set if the falling edge is input to any one of KR4-KR7, because KR4-KR7 inputs are ANDed in the $\mu$ PD75328. Fig. 6.3-4 shows the format of the edge detection mode registers used to select detected edge (IM0 to IM2). IM0 to IM2 are set individually by using a 4-bit memory operation instruction. When RESET signal is generated, all the register bits are cleared; INT0, INT1, and INT2 detection edges are specified to rising edges. Fig. 6.3-1 INTO and INT1 Configuration Fig. 6.3-2 INT2 and KR0-KR7 Configuration When a high level is input successively, the noise eliminator outputs a high level; when a low level is input successively, it outputs a low level. Fig. 6.3-3 Noise Eliminator Input/Output Timing Caution: If the edge detection mode register is changed, the interrupt request flag may be set. Disable interrupts beforehand, and change the mode register. Clear the interrupt request flag by using the CLR1 instruction before enabling interrupts. If f<sub>x</sub>/64 is selected for the sampling clock in an IMO change, clear the interrupt request flag within 16 machine cycles after the mode register is changed. Fig. 6.3-4 Edge Detection Mode Register Format (3) Interrupt master enable flag (IME) Interrupt master enable flag enables or disables acknowledgement of all interrupts. IME is set to 1 or to 0 by using the EI and DI instructions. When the RESET signal is generated, IME is cleared, disabling acknowledgement of all interrupts. #### Address Fig. 6.3-5 IME Format #### (4) Interrupt status flag The interrupt status flag (IST0) indicates the current status of processing being performed by CPU; it is contained in the PSW. The interrupt control circuit controls multi-interrupts (as listed in Table 6.3-2) according to the contents of interrupt status flag. Since IST0 can be changed by using a 4-bit or a one-bit manipulation instruction, multi-interrupt can also be implemented by changing the status of processing being performed. Multi-interrupt can always be implemented regardless of the MBE setting when IST0 is handled bitwise. Be sure to execute the DI instruction to disable interrupts before handling IST0 and the EI instruction to enable interrupts after handling IST0. When an interrupt is acknowledged, IST0 is saved in stack memory together with other PSW bits, then it is automatically set to 1. When the RETI instruction is executed, the former IST0 value (0) is restored. When the RESET signal is generated, the flag is cleared. Table 6.3-2 ISTO and Interrupt Service State | IST0 | Status of processing | CPU processing contents | Interrupt requests that can be acknowledged | After interrupt is acknowledged | |------|----------------------|----------------------------------|---------------------------------------------|---------------------------------| | 1 | | | | IST0 | | 0 | Status 0 | During normal program processing | All interrupts can be acknowledged. | 1 | | 1 | Status 1 | During interrupt service | None of the interrupts can be acknowledged. | _ | #### 6.4 Interrupt Sequence When an interrupt occurs, it is processed as shown in Fig. 6.4-1. Remarks: 1. IST0: Interrupt status flag (PSW bit 2). (See Table 6.3-2) 2. Store the interrupt service program start addresses and MBE setup values at the interrupt start in the vector table. Fig. 6.4-1 Interrupt Service Flow ### 6.5 Multi-interrupt Service Control The µPD75328 enables multi-interrupts as described below. As understood from Table 6.3-2, multi-interrupt is enabled if the interrupts status flag is changed by a program. That is, multi-interrupt is enabled if IST0 is changed to 0 by the interrupt service program setting status 0. To change IST0, execute the DI instruction beforehand to disable interrupts. Fig. 6.5-1 Multi-Interrupt by Changing Interrupt Status Flag #### 6.6 Vector Address Share Interrupt Service Since INTBT and INT4 interrupt sources share the vector table addresses, interrupt source selection is made as described below: #### (1) To use one interrupt only Set the interrupt enable flag to 1 for the required one of the two interrupt sources sharing the vector table addresses, and clear the interrupt enable flag of the other interrupt source. In this case, an interrupt request is generated from the interrupt source corresponding to the interrupt enable flag that is set to 1 (IEXXX = 1). When the interrupt request is acknowledged, the interrupt request flag is cleared. # (2) To use both interrupts Set both the interrupt enable flags of the two interrupt sources to 1. In this case, an interrupt request is made by ORing the interrupt request flags of the two interrupt sources. Even if an interrupt request is acknowledged when either or both of the interrupt request flags are set to 1, the interrupt request flags are not reset. Therefore, the interrupt service routine must decide which interrupt source the interrupt is generated from. This is accomplished by executing the SKTCLR instruction to check the interrupt request flags. If both the interrupt request flags are set to 1 when the request flags are tested and cleared by execution of the SKTCLR instruction, the interrupt request is left even if one request flag is cleared. If IST0 is cleared, dual interrupt service is entered according to the left interrupt request. Remarks: When only one interrupt is enabled, the source of an interrupt is known. Thus, the interrupt request flag is cleared by hardware when interrupt is acknowledged. When both interrupts are enabled, the source of an interrupt is not defined; thus, interrupt request flag cannot be cleared by hardware. Software is used to check the interrupt request flags and determine the interrupt source. Interrupt request flag is cleared by software. Example: When INT4 takes precedence over INTBT #### 6.7 Machine Cycles to Interrupt Service Start The number of the $\mu$ PD75328 machine cycles required to start execution of the interrupt routine after an interrupt request flag is set is as shown below: (1) When IRQn is set during execution of an operating instruction at data memory address FBxH (interrupt hardware)) FBxH address operating instruction As shown above, interrupt routine processing is started a maximum of six machine cycles after the data memory (address FBxH) operating instruction is terminated. (Within a maximum of six machine cycles after the last operating instruction is terminated if the FBxH address operating instructions are successive.) (2) When IRQn is set during execution of instruction other than in (1). In this case, a maximum of six machine cycles are required. ## 6.8 Effective Use of Interrupts Use the interrupt function as described below: (1) Set MBE = 0 in the interrupt service routine. If the data memory area used in the interrupt service routine is preferentially allocated to addresses 0-7FH and MBE = 0 is set in the interrupt vector table, a program can be prepared without considering memory banks. If memory bank 1 must be used for by the program, save the memory bank select register by using the PUSH BS instruction and select memory bank 1. (2) Use software interrupt for debugging. When an interrupt request flag is set by an instruction, operating is performed in the same manner as if an interrupt occurred. Debugging when more than one interrupt occurred at the same time can be done effeciently by using an instruction to set an interrupt request flag. #### 6.9 Interrupt Application To use the interrupt function, first set the following in the main program: - (1) Set the interrupt enable flags to be used (EI IEXXX instructions). - (2) To use INT0 and INT1, select the active edge. (set IM0 and IM1.) - (3) Set the interrupt master enable flag (El instruction). Since MBE is set by using the vector table in an interrupt service program, registers need not be saved or restored, and the interrupt program can be started immediately. To return from the interrupt service program, use the RETI instruction. #### (1) Interrupt enable and disable - ① All interrupts are disabled by the RESET signal. - ② The interrupt enable flags are set by the El IEXXX instructions. At this stage, all interrupts remain disabled. - ® The interrupt master enable flag is set by the El instruction. At this stage, INTO and INTTO are enabled. - The interrupt enable flag is cleared by the DI IEXXX instruction and INTO is disabled. - (5) All interrupts are disabled by the DI instruction. (2) Usage example of INTBT, INTO (falling edge active), and INTTO. Multi-interrupt is not done. - ① All interrupts are disabled by the RESET signal and status 0 is set. - Palling edge active is selected for INTO. - ③ Interrupts are enabled by the EI and EI IEXXX instructions. - On the INTO falling edge, the INTO interrupt service program is started. The status is changed to status 1 and all interrupts are disabled. - A return is made from the interrupt service program by the RETI instruction. The status is restored to status 0 and interrupts are enabled. (3) Pending interrupt execution - interrupt input during interrupt disable - - ① If INT0 is set during interrupt disable, the request flag is held. - When interrupts are enabled by the El instruction, the INTO service program is started. - ③ Simular to ① above. - When INTCSI is held enabled, the INTCSI service program is started. ## (4) Pending interrupt execution ① If INTO and INTTO are occured at the same time during execution of a single instruction, INTO, which is higher in priority than INTTO, is executed first; INTTO is held. When a return is made from the INTO service program by the RETI instruction, the held INTTO service program is started. (5) Enable of two double interrupts - INTTO and INTO enable double interrupts; INTCSI and INT4 are single interrupts - - ① When interruptINTCSI occurs, which does not enable double interrupts, the INTCSI service program is started. Status 1 is set. - ② The status is changed to status 0 by clearing IST0. INTCSI and INT4 do not enable double interrupt and are disabled. - When INTTO enables double interrupts, the double interrupt is executed, the status is changed to status 1, and all interrupts are disabled. - At the termination of INTTO service, the status is restored to status 0. - ⑤ Disabled INTCSI and INT4 are enabled and a return is made by the RETI instruction. #### 7. STANDBY FUNCTION To make the most of low current consumption, which is one feature of the CMOS process, the $\mu$ PD75328 can stop CPU operation in the standby mode making current consumption by the CPU very small. The $\mu PD75328$ standby mode includes the STOP mode and HALT mode. The STOP mode stops the main system clock oscillator. In this mode, CPU current consumption consists almost entirely of leakage current. Data memory can also be held with low supply voltage (up to $V_{DD} = 2$ V). This features is useful for maintaining the data memory contents with very low current consumption. Since the $\mu$ PD75328 STOP mode can be released by using an interrupt request, intermittent operation can also be performed. However, if processing must be started immediately when an interrupt request is made, note that the wait time required to ensure oscillator stability is taken when the STOP mode is released. The HALT mode continues system clock oscillator operation but stops the CPU clock $(\Phi)$ supply; thus, CPU operation is stopped. Although the HALT mode is inferior to the STOP mode for reduction of current consumption, it is useful to restart processing immediately according to an interrupt request or for performing intermittent operations such as watch operation. In either mode, all the register, flag, and data memory contents immediately before the standby mode is entered are held. The input/output port output latch state and output buffer state are also held. The input/output port state is handled beforehand so that the current consumption of the entire system is minimized. #### Cautions on Use of Standby Mode: for the clock change. - The STOP mode can be used only when μPD75328 operation uses the main system clock. (Subsystem clock oscillation cannot be stopped.) The HALT mode can be used when the μPD75328 uses either main system or subsystem clock. - If the STOP mode is set when the LCD controller/driver and watch clock operate on the main system clock f<sub>x</sub>, they stop operation. To continue operation, change to the subsystem clock f<sub>xT</sub> before setting STOP mode. - 3. Although efficient operation with low current consumption and low voltage can be performed by using the clock change function between the CPU and system clocks in combination with the standby mode, time (described in 5.2.3) is required from selection of a new clock by setting the control register until operation is started by the newly selected clock. Thus, to use the clock change function and the standby mode in combination, set the standby mode within the time required #### 7.1 Standby Mode Setting and Operating State Table 7.1-1 Operating State in Standby Mode | | | STOP mode | HALT mode | | | |-----------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--| | Setting instr | ruction | STOP instruction | HALT instruction | | | | System cloc | k when standby mode is set. | Can be set only during main system clock. | Can be set during either main system or subsystem clock. | | | | | Clock oscillator | Only the main system clock oscillator is stopped. | Only CPU clock $\Phi$ is stopped (oscillation is continued). | | | | | Basic interval timer | Operation stop | Operation (IRQBT is set at reference time intervals.) | | | | | Serial interface | Can operate only when external SCK input is selected for serial clock. | Can operate. | | | | Operating state | Timer/event counter | Can operate only when TI0 pin input is selected for count clock. | Can operate. | | | | | Watch timer | Can operate when $\mathbf{f}_{\mathrm{XT}}$ is selected for count clock. | Can operate. | | | | | LCD controller | Can operate only when $f_{XT}$ is selected for LCDCL. | Can operate. | | | | | A/D converter | Operation stop | Can operate | | | | | External interrupts | INT1, INT2, and INT4 can operate. Only | INT0 cannot operate. | | | | | CPU | Operation stop | | | | | Release sig | nal | Interrupt request signal enabled with interrupt enable flag from operating hardware (exept for INT0), or RESET input. | | | | The STOP mode is set by using the STOP instruction to set PCC bit 3; the HALT mode is set by the using HALT instruction to set PCC bit 2. To change the CPU clock by using the low-order two bits of PCC, a time lag may occur from PCC rewrite to CPU clock change. Thus, to change the clock before the standby mode is entered or after the standby mode is released, set the standby mode within the number of machine cycles required to change the CPU clock after PCC is rewritten. While operation stops during the standby mode, data is held in all registers and data memory such as general-purpose registers, flags, mode register, and output latches. Caution: 1. When the STOP mode is set, X1 input is short-circuited to V<sub>SS</sub> (GND potential) internally to suppress crystal oscillator leakage. Therefore, so not use the STOP mode in a system using external clock as a main system slock. 2. Since an interrupt request signal is used to release the standby mode, if both interrupt request and enable flags are set for an interrupt source, the standby mode is immediately released. Thus, for the STOP mode, the HALT mode is entered immediately after execution of the STOP instruction, a wait is followed according to the setup time of the BTM register, then a return is made to the operation mode. #### 7.2 Standby Mode Release The standby mode (STOP or HALT) is released when an interrupt request signal (except INT0) enabled with an interrupt enable flag occurs or RESET is input. Fig. 6.2-1 shows the standby mode release operation. Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (d) Releasing HALT node by interrupt generation Note: Broken line shows a case when standby releasing interrupt request is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation (cont'd) If the STOP mode is released when an interrupt occurs, the wait time is determined by BTM setting. (See Table 7.2-1.) The time until oscillation becomes stable varies according to the type of oscillator being used and the supply voltage when the STOP mode is released. Therefore, select the wait time according to the conditions of use and set BTM before setting the STOP mode. Table 7.2-1 Wait Time Selection by Using BTM | втмз | ВТМ2 | ВТМ1 | втмо | Wait time* ( ) indicates f <sub>XX</sub> = 4.19 MHz | |---------|------------------|------|------|------------------------------------------------------------| | - | 0 | 0 | 0 | APPROX. 2 <sup>20</sup> /f <sub>XX</sub> (Approx. 250 ms) | | - | 0 | 1 | 1 | APPROX. 2 <sup>17</sup> /f <sub>xx</sub> (Approx. 31.3 ms) | | - | 1 | 0 | 1 | APPROX. 2 <sup>15</sup> /f <sub>XX</sub> (Approx. 7.82 ms) | | - | 1 | 1 | 1 | APPROX. 2 <sup>13</sup> /f <sub>xx</sub> (Approx. 1.95 ms) | | Other t | Other than above | | | Use Prohibited | Note: The wait time when STOP mode is released does not include the time until the clock begins to oscillate after STOP mode is released ((a) in the figure below) regardless of whether STOP mode was released by RESET input or interrupt generation. #### 7.3 Operation After Standby Mode is Released - (1) If the standby mode is released when RESET is input, normal reset operation is performed. - (2) If the standby mode is released when an interrupt request occurs, the contents of the interrupt master enable flag (IME) determine whether or not a vectored interrupt is made when the CPU restarts instruction execution. - (a) When IME = 0 - After the standby mode released, execution restarts at the NOP instruction next to the standby mode setting instruction. The interrupt request flags are held. - (b) When IME = 1 After the standby mode is released, two instructions following the standby mode setting instruction are executed before a vectored interrupt is executed. However, if the standby mode is released by using INTW or INT2 (testable input), no vectored interrupt will occur; processing as in (a) above is performed. #### 7.4 Standby Mode Application To use the standby mode, follow the procedure described below: - Detect a standby mode setting source such as interrupt input or port input for power off (it is effective to use INT4 for power off detection). - Handle input/output ports so that current consumption is minimized. - 3) Specify interrupt to release the standby mode. (It is effective to use INT4. Clear the interrupt enables flags so as not to release the standby mode.) - 4) Specify operation after the standby mode is released (set IME depending on whether or not interrupt service is made). - 5) Specify the CPU clock after the standby mode is released. (To change the clock, wait for the required number of machine cycles before setting the standby mode.) - 6) Select the wait time in release of standby mode. - 7) Set the standby mode by using the STOP or HALT instruction. Use of the standby mode and system clock change function in combination enables the $\mu PD75328$ to operate at low current consumption and low voltage. ## (1) Example of STOP mode application Use the STOP mode under the following conditions - Set the STOP mode when the INT4 falling edge is input and release it when the rising edge is input. (Do not use INTBT.) - Place all input/output ports in high impedance. - Use interrupts INT0 and INTT0 in the example program; however, do not use them to release the STOP mode. - Enable interrupts after the STOP mode is released. - After the STOP mode is released, start operation on the minimum speed CPU clock, and in 250 ms, change it to high-speed clock. - Set the wait time for STOP mode release to about 31.3 ms. - After the STOP mode is released, wait for 31.3 ms for the power supply to become stable. Check the P00/INT4 pin twice and remove chattering. ## (2) HALT mode application Perform intermittent operation under the following conditions - Change to the subsystem clock on the falling edge of INT4. - Stop oscillation of the main system clock and set the HALT mode. - Perform intermittent operation at 0.5sec. intervals during the standby mode. - Again change to the main system clock on the rising edge of INT4. - Do not use INTBT. MOV WM, XA **RETI** PDOWN: MOV XA, #05H ; Subsystem clock MOV WM, XA MOV XA, #00H MOV ; LCD display off LCDM, XA MOV LCDC, A SET1 SCC.0 ; Change to subsystem clock MOV A, #6 WAIT2: INCS ; Wait for 32 machine cycles BR WAIT2 SET1 ; Stop oscillation of main system clock SCC.3 RETI Note: When the system clock is changed after power on from main system clock to subsystem clock, change the system clock after the subsystem clock is stabilized. # 8. RESET FUNCTION The μPD75328 is reset when RESET is input. The hardware devices are initialized as listed inTable 8.1-1. Fig. 8.1-1 shows the reset operation timing. Fig. 8.1-1 Reset Operation by RESET is input Table 8.1-1 State After Each Hardware Device is Reset | | Har | dware | RESET input during standby mode | RESET input during operation | |-------------------|----------------|-------------------------------|---------------------------------------------------------------------------|------------------------------| | Program | counter (PC | μPD75328 | The low-order five bits of program me PC12-PC8. The contents of address 0 | | | PSW | Carry flag | (CY) | Held | Undefined | | | Skip flag | (SK0-SK2) | 0 | 0 | | | Interrupt | status flag (IST0) | 0 | 0 | | | Bank ena | ble flag | Bit 7 of program memory address 000 | 0H is loaded into MBE. | | Stack po | inter (SP) | | Undefined | Undefined | | Data memory (RAM) | | | Held (Note) | Undefined | | General- | purpose regis | ters (X, A, H, L, D, E, B, C) | Held | Undefined | | Bank sel | ection registe | r (MBS) | 0 | 0 | | Basic inte | erval timer | Counter (BT) | Undefined | Undefined | | | | Mode register (BTM) | 0 | 0 | | Timer ev | ent counter | Counter (T0) | 0 | 0 | | | | Modulo register<br>(TMOD0) | FFH | FFH | | | | Mode register (TM0) | 0 | 0 | | T | | TOE0, TOUT F/F | 0, 0 | 0, 0 | | Watch tir | ner | Mode register (WM) | 0 | 0 | | Serial int | erface | Shift register (SIO) | Held | Undefined | Table 8.1-1 State After Each Hardware Device is Reset (Cont'd) | | Hardware | RESET input during standby mode | RESET input during operation | |--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------| | Serial | Operation mode register (CSIM) | 0 | 0 | | interface | SBI control register (SBIC) | 0 | 0 | | | Slave address register (SVA) | Held | Undefined | | Clock<br>generator | Processor clock control register (PCC) | 0 | 0 | | and clock<br>output<br>circuit | System clock control register (SCC) | 0 | 0 | | on out | Clock output mode register (CLOM) | 0 | 0 | | LCD | Display mode register (LCDM) | 0 | 0 | | controller | Display control register (LCDC) | 0 | 0 | | A/D | Mode register (ADM) | 04H (EOC = 1) | 04H (EOC = 1) | | converter | SA register | 7FH | 7FH | | Interrupt | Interrupt request flags (IRQXXX) | Reset to 0 | Reset to 0 | | function | Interrupt enable flags (IEXXX) | 0 | 0 | | | Interrupt master enable flag (IME) | 0 | 0 | | | INT0, INT1, and INT2 mode registers (IM0, IM1, and IM2) | 0, 0, 0 | 0, 0, 0 | | Digital | Output buffers | Off | Off | | ports | Output latches | Cleared | Cleared | | | Input/output mode registers (PMGA, B, C) | 0 | 0 | | | System clock control register (SCC) Clock output mode register (CLOM) Display mode register (LCDM) Display control register (LCDC) Mode register (ADM) SA register Interrupt request flags (IRQXX) Interrupt enable flags (IEXXX) Interrupt master enable flag (IN INTO, INT1, and INT2 mode registers (IMO, IM1, and IM2) all Output buffers Output latches Input/output mode registers (PMGA, B, C) Pull-up resistor specification register (POGA, B) equential buffer (BSB0-BSB3) P00-P03, P10-P13, P20-P23, P3 | 0 | 0 | | Bit sequent | tial buffer (BSB0-BSB3) | Held | Undefined | | Pins<br>condition | P00-P03, P10-P13, P20-P23, P30-<br>P33, P60-P63, P70-P73, P80-P83 | Input | Input | | | P40-P43, P50-P53, | | High level<br>High impedance | | | S12-S23, COM0-COM3 | No | te 2 | | | BIAS | At incorporated split resistor: At not incorporated split resistor: | Low level<br>High impedance | Note: The data of data memory address 0F8H-0FDH is undefined by RESET input. Note2: Each display output is selected as V<sub>LCX</sub> input source. S12-31: V<sub>LC1</sub> COM0-COM2: V<sub>LC2</sub> COM3: V<sub>LC0</sub> However, each display output level is changed by each display output and V<sub>LCX</sub> external circuit. ## 9. ELECTRICAL CHARACTERISTICS # Absolute Maximum Ratings (Ta = 25 °C) | Item | Symbol | | Conditions | | Ratings | Unit | | |-----------------------|---------------------|--------------------------|---------------|------------------|------------------------------|------|--| | Supply voltage | V <sub>DD</sub> | | | -0.3 to +7.0 | ٧ | | | | Input voltage | V <sub>I1</sub> | Other than ports 4 and 5 | | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | | V <sub>I2</sub> (1) | Ports 4 and 5 | With internal | pull-up resistor | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | | | | Open drain | | -0.3 to +11 | ٧ | | | Output voltage | v <sub>o</sub> | | | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | High level | I <sub>oh</sub> | Single pin | | | -15 | mA | | | output current | | Total, all outputs | | | -30 | | | | Low level | l <sub>oL</sub> | Single pin | | Peak value | 30 | | | | output current | Note | | | Effective value | 15 | | | | | | Ports 0, 2, 3, 5 and | d 8 total | Peak value | 100 | | | | | | | | Effective value | 60 | mA | | | | | Ports 4, 6, and 7 to | otal | Peak value | 100 | | | | | | Effective value | | Effective value | 60 | | | | Operation Temperature | T <sub>opt</sub> | | | -40 to +85 | °C | | | | Storage Temperature | T <sub>stg</sub> | | | | -65 to +150 | °C | | Note: Use the following formula to calculate the effective value. (Effective value) = (Peak value) $\times \sqrt{\text{duty}}$ # Characteristics of Main System Clock Oscillator (Ta = -40 to +85 $^{\circ}$ C, $V_{DD} = 2.7$ to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------|----------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|------|------| | Ceramic | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 1.0 | | 5.0 | MHz | | resonator | C1 + C2<br>V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization time | After V <sub>DD</sub> reaches the minimum value in the oscillator voltage range | | | 4 | ms | | Crystal | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 1.0 | 4.19 | 5.0 | MHz | | resonator | C1 ± C2<br>V <sub>DD</sub> | Note 2<br>Oscillation | V <sub>DD</sub> =4.5 to 6.0V | | | 10 | ms | | | DB | stabilization time | | | | 30 | ms | | External clock | X1 X2 | Note 1<br>X1 input frequency<br>(f <sub>X</sub> ) | | 1.0 | | 5.0 | MHz | | External clock | Д µРD74HCU04 | X1 input high/low level width (t <sub>XH</sub> , t <sub>XL</sub> ) | | 100 | N. | 500 | ns | Note 1: The oscillation frequency and X1 input frequency are indicated only to express the characteristics of the oscillator. Refer to the AC characteristics for instruction execution time. Note 2: The oscillation stabilization time is the time required for the oscillator to stabillate after V<sub>DD</sub> is applied or after the STOP mode is released. # Subsystem Clock Oscillator Characteristics (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |-----------------------|-----------------------|-----------------------------------------------------------------------|-----------------------|------|--------|------|------| | Crystal | XT1 XT2 | Oscillation frequency $(f_{XT})$ | | 32 | 32.768 | 35 | MHz | | resonator 22 pm 133 p | 22 pF 133 pF | Oscillation | $V_{DD} = 4.5 - 6.0V$ | | 1 | 2 | s | | | V <sub>pD</sub> | Stabilization time | | | | 10 | s | | External clock | XT1 XT2 | XT1 input frequency (f <sub>XT</sub> ) | | 32 | | 100 | kHz | | External clock | Å Open | XT1 input high/low level width (t <sub>XTH</sub> , t <sub>XTL</sub> ) | | 5 | | 15 | μs | #### **Recommended Resonator** Main system clock: ceramic resonator | Maunfacture | Product name | | ernal<br>ors (pF) | Oscillator<br>voltage r | Remarks | | |-------------|---------------------------------------------|--------------|-------------------|-------------------------|---------|-----------------| | | | C1 | C2 | MIN. | MAX. | | | | CSA 2.00MG093 | 15 | 15 | 2.5 | 3.5 | Note | | Murata | CSB 1000D20 | 220 220 | | | | | | | CSA 2.00MG093<br>CSA 4.19MGU<br>CSA 4.91MGU | 30 | 30 | 2.7 | 6.0 | | | | CST 2.00MG093<br>CST 4.19MGU<br>CST 4.91MGU | not required | not required | | | Internal C type | | | KBR-1000H | 100 | 100 | | | | | | KBR-2.0MS | 47 | 47 | ^ | | | | Kyocera | KBR-4.0MS<br>KBR-4.19MS<br>KBR-4.91MS | 33 | 33 | 2.7 | 6.0 | | Note: When CSA 2.000G093 is used, VDD is 2.5 to 3.5V. Main system clock: crystal resonator | Maunfacture | Freg. Holder | External capacitors (pF) | | Oscillator<br>voltage r | Remarks | | |-------------|------------------------------------------------------|--------------------------|----|-------------------------|---------|--| | | | C1 | C2 | MIN. | MAX. | | | Kinseki | 1.00<br>2.00 HC-18/U<br>4.19 HC-49/U<br>4.91 HC-43/U | 22 | 22 | 2.7 | 6.0 | | # Subsystem clock: 32.768 KHz crystal resonator | Maunfacture | Product name | External capacitors (pF) | | | Oscillator<br>voltage r | Remarks | | |-------------|--------------|--------------------------|---------|--------|-------------------------|---------|--| | | | C1 (pF) | C2 (pF) | R (kΩ) | MIN. | MAX. | | | Kinseki | P-3 | 22 | 22 | 330 | 2.7 | 6.0 | | # Capacitance (Ta = 25 $^{\circ}$ C, V<sub>DD</sub> = 0V) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Units | |--------------------------|------------------|---------------------------|------|------|------|-------| | Input capacitance | C <sub>IN</sub> | f =1 MHz | | | 15 | pF | | Output capacitance | C <sub>OUT</sub> | For other than pins to be | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | measured, 0V. | | | 15 | pF | # **DC Characteristics** (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | | | UU | | | | | | |------------------------------------|-------------------|------------------------------------------|--------------------------------------------------------------------------|----------------------|------|--------------------|------| | ltem | Symbol | | Conditions | MIN. | TYP. | MAX. | Unit | | High level input | V <sub>IH1</sub> | Ports 2 and 3 | | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | voltage | V <sub>IH2</sub> | Ports 0, 1, 6, 7, and RESET pin | | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | | | V <sub>IH3</sub> | Ports 4 to 5 | With built-in pullup resistor | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | | | Open drain | 0.7V <sub>DD</sub> | | 10 | ٧ | | | V <sub>IH4</sub> | X1, X2, XT1 | (1, X2, XT1 | | | V <sub>DD</sub> | ٧ | | Low level input | V <sub>IL1</sub> | Ports 2, 3, 4, 5 | | 0 | | 0.3V <sub>DD</sub> | ٧ | | voltage | V <sub>IL2</sub> | Ports 0, 1, 6, 7, and | d RESET pin | 0 | | 0.2V <sub>DD</sub> | ٧ | | | V <sub>IL3</sub> | X1, X2, XT1 | | 0 | | 0.4 | ٧ | | High level output voltage | V <sub>OH1</sub> | Ports 0, 2, 3, 6, 7, 8 BIAS | $V_{DD} = 4.5 \text{ to } 6.0 \text{V}$<br>$I_{OH} = -1 \text{mA}$ | V <sub>DD</sub> -1.0 | | | V | | | | | $I_{OH} = -100 \mu A$ | V <sub>DD</sub> -0.5 | | | ٧ | | | V <sub>OH2</sub> | BP0-7 (with two I <sub>OH</sub> outputs) | $V_{DD} = 4.5 \text{ to } 6.0V$<br>$I_{OH} = -100 \mu A$ | V <sub>DD</sub> -2.0 | | | ٧ | | | | | $I_{OH} = -30\mu A$ | V <sub>DD</sub> -1.0 | | | ٧ | | Low level output voltage | V <sub>OL1</sub> | Port 0, 2 – 8 | Ports 3, 4, 5<br>V <sub>DD</sub> = 4.5 to 6.0V<br>I <sub>OL</sub> = 15mA | | 0.4 | 2.0 | ٧ | | | | | V <sub>DD</sub> = 4.5 to 6.0V<br>I <sub>OL</sub> = 1.6mA | | | 0.4 | ٧ | | | | | I <sub>OL</sub> = 400μA | | | 0.5 | ٧ | | | | SB0, 1 | Open drain Pull-up register $\geq 1 k\Omega$ | | | 0.2V <sub>DD</sub> | V | | | V <sub>OL2</sub> | BP0-7 (with two I <sub>OL</sub> outputs) | $V_{DD} = 4.5-6.0V$ $I_{OL} = 100\mu A$ | | | 1.0 | ٧ | | | | | I <sub>OL</sub> = 50μA | | | 1.0 | ٧ | | High level input leakage current | I <sub>LIH1</sub> | $V_{IN} = V_{DD}$ | Other than indicated below | | | 3 | μА | | rearrage our ent | I <sub>LIH2</sub> | | X1, X2, XT1 | | | 20 | μΑ | | | I <sub>LIH3</sub> | V <sub>IN</sub> = 10V | Ports 4, 5 (with open drain) | | | 20 | μΑ | | Low level input<br>leakage current | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V | Other than indicated below | | | -3 | μΑ | | leakage current | I <sub>LIL2</sub> | | X1, X2, XT1 | | | -20 | μΑ | | High level output leakage current | I <sub>LOH1</sub> | $V_{OUT} = V_{DD}$ | Other than indicated below | | | 3 | μА | | .canago current | I <sub>LOH2</sub> | V <sub>OUT</sub> = 10V | Ports 4 and 5 (with open drain) | | | 20 | μΑ | | Low level output leakage current | I <sub>LOL</sub> | V <sub>OUT</sub> = 0V | | | | -3 | μА | | Internal pull-up resistor | R <sub>L1</sub> | Ports 0,1,2,3,6,8<br>(Except P00) | $V_{DD} = 5.0V \pm 10\%$ | 15 | 40 | 80 | kΩ | | 10313101 | | V <sub>IN</sub> = 0V | $V_{DD} = 3.0V \pm 10\%$ | 30 | | 200 | kΩ | # DC Characteristics (Ta = -40 to +85 °C, $V_{DD} = 2.7$ to 6.0V) | Item | Symbol | | Condition | าร | | MIN. | TYP. | MAX. | Unit | |----------------------------------------------|------------------|-----------------------------------------|-------------------------------------------|------------------------------------------------|-----------|------|------|-----------------|------| | Internal pull-up resistor | R <sub>L2</sub> | Ports 4 and 5 | V <sub>DD</sub> = 5. | 0V ± 10% | | 15 | 40 | 70 | kΩ | | resistor | | V <sub>OUT</sub> =V <sub>DD</sub> -2.0V | V <sub>DD</sub> = 3. | 0V ± 10% | • | 10 | | 60 | kΩ | | LCD drive voltage | V <sub>LCD</sub> | | | | | 2.5 | | V <sub>DD</sub> | ٧ | | LCD split resistor | R <sub>LCD</sub> | | | | | 60 | 100 | 150 | kΩ | | LCD output<br>voltage deviation<br>(common) | V <sub>ODC</sub> | I <sub>O</sub> = ±5μA | V <sub>LCD0</sub> = V <sub>LCD1</sub> = 1 | V <sub>LCD</sub> x <sup>2</sup> / <sub>3</sub> | | 0 | | ± 0.2V | V | | LCD output<br>voltage deviation<br>(segment) | V <sub>ops</sub> | $I_O = \pm 1 \mu A$ | $V_{LCD2} = V_{LCD} x^{1}/_{3}$ Note 4 | | i<br> | 0 | | ± 0.2V | ٧ | | Supply current<br>(Note 1) | | (Note 5)<br>4.19 MHz crystal | V <sub>DD</sub> = 5\ | / ± 10% ( | Note 2) | | 2.5 | 8 | mA | | (Note 1) | DD1 | oscillation<br>C1=C2=22pF | V <sub>DD</sub> = 3V ± 10% (Note 3) | | | 0.35 | 1.2 | mA | | | | | 01=02=22μι | HALT<br>Mode | V <sub>DD</sub> = 5 | V ± 10% | - | 500 | 1500 | μА | | | DD2 | | Mode | V <sub>DD</sub> = 3 | V ± 10% | | 150 | 450 | μΑ | | | I <sub>DD3</sub> | 32kHz crystal resonator | V <sub>DD</sub> = 3\ | / ± 10% | | | 30 | 90 | μΑ | | | I <sub>DD4</sub> | (Note 6) | HALT<br>Mode | V <sub>DD</sub> = 3 | V ± 10% | | 5 | 15 | μΑ | | | | XT1 = 0 | V <sub>DD</sub> = 5\ | / ± 10% | | | 0.5 | 20 | μА | | | I <sub>DD5</sub> | STOP mode | V <sub>DD</sub> = 3\ | / ± 10% | | | 0.1 | 10 | μА | | | | | | | Ta = 25°C | | 0.1 | 5 | μΑ | Note 1: The currents of the built-in pull-up resistor and the LCD step-down resistor are not included. Note 2: When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. Note 3: When operated in the low-speed mode with the PCC set to 0000. Note 4: 2.7V $\leq$ V<sub>LCD</sub> $\leq$ V<sub>DD</sub> Note 5: Includes the power consumption for the subsystem oscillation. Note 6: When the system clock control registor (SCC) is set to 1001, main system clock oscillation is stopped and operated by subsystem clock. # A/D Converter characteristics (Ta = -10 to +85 C, $V_{DD} = 3.5$ to 6.0V, $AV_{SS} = V_{SS} = 0$ V)) | ltem | Symbol | Condition | MIN. | TYP. | MAX | Unit | |----------------------------|-------------------|---------------------------------------------|------------------|------|--------------------|------| | Resolution | | | 8 | 8 | 8 | bit | | Absolute accuracy (Note 1) | | 2.5 V ≤ V <sub>AREF</sub> ≤ V <sub>DD</sub> | | | ± 1.5 | LSB | | Conversion time | t <sub>CONV</sub> | Note 2 | | | 168/f <sub>X</sub> | S | | Sampling time | t <sub>SAMP</sub> | Note 3 | | | 44/f <sub>X</sub> | S | | Analog input voltage | VIAN | | AV <sub>ss</sub> | | VAREF | ٧ | | Analog input impedance | R <sub>AN</sub> | | | 1000 | | МΩ | | V <sub>AREF</sub> current | IAREF | | | 1.0 | 2.0 | mA | Note 1: Absolute accuracy, which does not include the quantization error (± 1/2LSB) Note 2: Time until EOC = 1 after conversion start instruction execution (40.1 $\mu$ s at 4.19 MHz (f<sub>v</sub>)). Note 3: Time until the completion of sampling after conversion start instruction execution (10.5µs at 4.19 MHz (f<sub>x</sub>)). # AC Characteristics (Ta = -40 to +85 C, $V_{DD}$ = 2.7 to 6.0V) | Item | Symbol | Condi | tion | MIN. | TYP. | MAX | Unit | |---------------------------------------------|-------------------|-------------------------------------|-----------------------------|--------|------|-----|------| | (Note 1) Cycle time<br>(minimum instruction | | Operation with main system clock | V <sub>DD</sub> = 4.5 -6.0V | 0.95 | | 64 | μs | | execution time) | | System clock | | 3.8 | | 64 | μs | | | t <sub>CY</sub> | Operation with sub-<br>system clock | | 114 | 122 | 125 | μs | | TIO input fraguancy | | $V_{DD} = 4.5 - 6.0V$ | <del></del> | 0 | | 1 | MHz | | TI0 input frequency | f <sub>TI</sub> | | 0 | | 275 | kHz | | | TI0 input high/low level width | t <sub>TIH</sub> | $V_{DD} = 4.5 - 6.0V$ | | 0.48 | | | μs | | Width | t <sub>TIL</sub> | | | 1.8 | | | μs | | Interrupt input high/low | t <sub>INTH</sub> | INT0 | | Note 2 | | | μs | | level width | | INT1, 2, 4 | | 10 | | | μs | | | t <sub>INTL</sub> | KR0-7 | | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | - | 10 | | | μs | Note 1: The cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure below shows the V<sub>DD</sub> vs cycle time $(t_{\rm CY})$ when operated with the main system clock. Note 2: $2t_{\rm CY}$ or $128/t_{\rm x}$ , depending on the setting of the interrupt mode register (IM0). **Serial Transfer Operation** 2-line/3line serial I/O mode (SCK ... Internal clock output) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-------------------|-----------------------------|----------------------------------|------|------|------| | 000 | | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | SCK cycle time | TKCY1 | | 3800 | | | ns | | SCK high/low level | t <sub>KL1</sub> | V <sub>DD</sub> = 4.5 -6.0V | <sup>t</sup> <sub>KCY1</sub> -50 | | | ns | | width | t <sub>KH1</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SI set-up time (against SCK ) | t <sub>SIK1</sub> | | 150 | | | ns | | SI hold time<br>(against SCK ) | t <sub>KSI1</sub> | | 400 | | | ns | | SCK - | | V <sub>DD</sub> = 4.5 -6.0V | | | 250 | ns | | SO output delay time | <sup>t</sup> kso1 | | | | 1000 | ns | # 2-line/3line serial I/O mode (SCK ... External clock input) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------|-------------------|-----------------------------|------|------|------|------| | 001/ | | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | SCK cycle time | t <sub>KCY2</sub> | | 3200 | | | ns | | SCK high/low level width | t <sub>KL2</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | 1 | ns | | | t <sub>KH2</sub> | | 1600 | | | ns | | SI set-up time (against SCK ) | t <sub>SIK2</sub> | | 100 | | | ns | | SI hold time (against SCK ) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK ↓ — | | V <sub>DD</sub> = 4.5 -6.0V | | | 300 | ns | | SO output delay time | <sup>t</sup> KSO2 | | | | 1000 | ns | Note: The output delay time (for rising edge) of the serial line must be shorter than 600 ns. For example, if SB0 and SBI are pulled up with 5K ohms, the total capacitance of the serial bus line must be no greater than 120 pF. # SBI mode (SCK ... Internal clock output (master)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------|-------------------|---------------------------------------|------------------------|------|------|------| | SCK cycle time | | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | SCR cycle time | tксүз | | 3800 | | | ns | | SCK high/low level | t <sub>KL3</sub> | V <sub>DD</sub> = 4.5 -6.0V | 1 <sub>KCY1</sub> -50 | | | ns | | width | t <sub>KH3</sub> | | 1 <sub>KCY1</sub> -150 | | | ns | | SB0,1 set-up time<br>(against SCK ) | t <sub>sık3</sub> | | 150 | | | ns | | SB0,1 hold time<br>(against SCK ) | t <sub>KSI3</sub> | · · · · · · · · · · · · · · · · · · · | t <sub>KCY1</sub> | | | ns | | SCK | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 250 | ns | | time | t <sub>KSO3</sub> | | 0 | | 1000 | ns | | SCK SB0,1↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1↓ → SCK↓ | t <sub>sbK</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | | ns | # SBI mode (SCK ... External clock input (slave)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------|-------------------|-----------------------------|-------------------|------|------|------| | SCK cycle time | | $V_{DD} = 4.5 - 6.0V$ | 800 | | | ns | | | t <sub>KCY4</sub> | | 3200 | | | ns | | SCK high/low level | t <sub>KL4</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | | ns | | width | t <sub>KH4</sub> | | 1600 | | | ns | | SB0,1 set-up time (against SCK ∤ ) | t <sub>SIK4</sub> | | 100 | | | ns | | SB0,1 hold time<br>(against SCK ) | t <sub>KSI4</sub> | | 1 <sub>KCY1</sub> | | | ns | | SCK - | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 300 | ns | | SB0,1 output delay time | t <sub>KSO4</sub> | | 0 | | 1000 | ns | | SCK - SB0,1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1↓ → SCK↓ | t <sub>sвк</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0,1 high level width | t <sub>SBH</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1 and XT1 inputs) # Serial Transfer Timing Interrupt input timing RESET input timing # Data Memory STOP Mode Low Voltage Data Retention Characteristic (Ta = -40 to +85 °C) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|------------------------------|------|---------------------------------|------|------| | Data retention voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention current (Note1) | I <sub>DDDR</sub> | V <sub>DDR</sub> = 2.0V | | 0.1 | 10 | μΑ | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | Oscillation stabilization time (Note 2) | | Release by RESET input | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | Oscillation stabilization time (Note 2) | twait | Release by interrupt request | | Note 3 | | ms | Note 1: Current in the internal pull-up resistors is not included. Note 2: The oscillation stabilization time is the time required before beginning CPU operation in order to prevent unstable CPU operation when oscillation is initiated. Note 3: Depends on the setting of the basic interval timer mode register (BTM) (refer to the table below). | втмз | BTM2 | BTM1 | втмо | WAIT time ( ) indicates f <sub>X</sub> =4.19MHz | | |------|------|------|------|---------------------------------------------------------|--| | _ | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>X</sub> (Approximately 250 ms) | | | _ | 0 | 1 | - 1 | 2 <sup>17</sup> /f <sub>X</sub> (Approximately 31.3 ms) | | | | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>X</sub> (Approximately 7.82 ms) | | | _ | 1 | 1 | 1 | 2 <sup>13</sup> /f <sub>X</sub> (Approximately 1.95 ms) | | Data Retention Timing (when STOP mode is released by RESET input) Data Retention Timing (Standby release signal: STOP mode release by interrupt signal) #### **Characteristic Curves** Power supply current IDD (µA) Power supply current IDD (µA) I<sub>DD</sub> vs V<sub>DD</sub> (Ceramic oscillation) (Ta = 25 °C) <sup>\*</sup>The Current values are increased by approximately 10% compared to when operating with a crystal resonator. (Ta = 25 °C) (Ta = 25 °C) \* Of pins BP0 to BP3 or BP4 to BP7, number of pins outputting the same level. #### 10. μPD75P328GC (OTPROM) 4-BIT MICROCOMPUTERS. #### 10.1 Overview The μPD75P328 is a single-chip 4-bit microcomputer which is supplied as a plastic otprom (one time programmable) or ceramic uvprom with window. The single-chip includes, timer/event counters, serial interface and vector interrupt. These functions are incorporated along with CPU, PROM, RAM and I/O ports. The μPD75P328 is pin-compatible with the μPD75P328GC and equivalent to the device in function. The µPD75P328 will be use for emulation of µPD75328. It should not be used for final EMI and latch up evaluation. | Memory type | μPD75P328GC-3B9 | |-------------|-----------------| | ROM | 8064 x 8 bit | | RAM | 512 x 4 bit | #### 10.2 Features 42 types of instructions. Numerous bit manipulation instructions. - 8-bit transfer instructions. - 1-byte relative branch instructions. GETI instruction that realizes arbitrary 2-byte instructions in 1-byte units. - Programmable instruction cycle: 0.95μs, 1.91μs, 15.3μs / 4.19MHz (main system oscillator), 122μs / 32kHz (sub system oscillator) at 5V - Size of data memory (RAM): 512 x 4 bit (memory bank configuration) - Memory-mapped I/O (memory bank configuration) - Memory for bit manipulation (bit-sequential buffer: 16 bits) - · General-purpose register: 4 bits x 8 (one register bank) - · Accumulators: Bit accumulator (CY) - 4-bit accumulator (A) - 8-bit accumulator (XA) - · LCD controller/driver - LCD drive segment outputs: 20 - LCD drive common outputs: 4 - LCD drive mode - static - 1/2 bias 1/2 duty, 1/3 duty - 1/3 bias 1/3 duty, 1/4 duty - External expansion port for LCD controller/driver, serial connection. - Internal 6 channel 8-bit precision A/D converter. - 36 I/O lines - CMOS In/Out Pins Middle-high voltage N-ch open drain In/Out Ports: 2 LED direct drive port: 3 - · Vector interrupt function capable of multiple interrupts, 3 external vector interrupts - 1 external test input - 3 internal vector interrupts 1 internal test interrupt - · Basic interval timer - One 8-bit timer/event counter - · Watch timer (0.5 sec test flag) - · 8 bit serial interface: - Conventional 75, 75X compatible mode - Serial bus interface (SBI) mode - · Internal clock oscillator with crystal/ceramic resonator - · Subsystem and main system oscillators, run CPU on 32kHz subsystem. - Standby operation (STOP/HALT) - CMOS low power consumption - µPD75P328GC: 80 PIN plastic flat pack one time programmable OTPROM II-4-182 #### 10.4 Pin Configuration ## 10.5 Pin Functions 10.5.1 Port Pins | Pin | Input/Output | Serve<br>Pin | | Ful | nctions | 8-Bit<br>I/O | At Reset | I/O Circuit<br>Type (Note 1) | | | |---------------------|---------------|--------------|-----|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------|---------------------|------------------------------|--|-----| | P00 | Input | INT | 4 | 4-bit input port (POF | | х | Input | B | | | | P01 | Input/Output | sc | K | Incorporation of pull-up resistors in 3-bit units for P01 to P03 specifiable by software. | | | | | | F-A | | P02 | Input/Output | SO/S | B0 | | | | | ⊕-B | | | | P03 | Input/Output | SI/S | ВІ | | | | | (M) -C | | | | P10 | Input | INT0 | | | Noise elimination | х | Input | B-C | | | | P11 | | INT | 1 | | function available | | | | | | | P12 | | INT | 2 | 4-bit input port (POF<br>Incorporation of pull- | RT1).<br>-up resistors in 4-bit units | | | | | | | P13 | | TIC | 0 | specifiable by software | are. | | | * 4 | | | | P20 | Input/Output | PTC | 00 | 4-bit input/output po | | х | Input | E-B | | | | P21 | | _ | - | Incorporation of pull-<br>specifiable by softwa | up resistors in 4-bit units are. | | | | | | | P22 | | PC | L | | | | | `. | | | | P23 | | BU | Z | | | | | | | | | P30 (Note 2) | Input /Output | LCDCL | MD0 | Programmable 4-bit input/output port Input/output setting is possible in bit units. In corporation of pull up resistors in 4 bit units | | х | Input | E-B | | | | P31 (Note 2) | | SYNC | MD1 | | | | | * | | | | P32 (Note 2) | | ME | )2 | specifiable by softwa | are. | | | | | | | P33 (Note 2) | | ME | )3 | | | | - | | | | | P40-P43<br>(Note 2) | Input/Output | _ | - | (PORT4).<br>Data input/output pi | Data input/output pin (lower 4-bits) for use during program memory (PROM) write/ | | High Im-<br>pedance | М-В | | | | P50-P53<br>(Note 2) | Input/Output | | | (PORT5). | in 4-bit input/output port<br>n (upper 4-bits) for use<br>nory (PROM) write/ | | High Im-<br>pedance | м-в | | | | P60 | Input/Output | KR | 10 | Programmable 4-bit | input/output port | 0 | Input | F-A | | | | P61 | | KR | 11 | | ecified for input/output in | | | | | | | P62 | | KR | 12 | bit units.<br>Incorporates softw | are-specifiable pull-up | | | | | | | P63 | | KR | 13 | resistors in 4-bit units. | | | | | | | | P70 | Input/Output | KR | 14 | | -bit input/output port (PORT7) | | Input | F-A | | | | P71 | | KF | 15 | Incorporation of pull-up resistors in 4-bit units specifiable by software. | | | | | | | | P72 | | KF | 16 | | | | | | | | | P73 | | KF | R7 | | | | | | | | | P80-P83 | Input/Output | _ | | | ort (PORT8).<br>stor can be specified for<br>its by using software. | x | Input | E-B | | | #### 10.5.1 Port Pins (cont'd) | Pin | Input/Output | Serves as<br>Pin for | Functions | 8-Bit<br>I/O | At Reset | I/O Circuit<br>Type (Note 1) | |-----|--------------|----------------------|-----------------------------------------|--------------|----------|------------------------------| | BP0 | Output | S24 | 1-bit output port (BIT PORT). | х | (Note 3) | G-A | | BP1 | | S25 | Also serves as the segment output pins. | | | | | BP2 | | S26 | | | | | | BP3 | | S27 | | | | | | BP4 | Output | S28 | | | - | | | BP5 | | S29 | | | | | | BP6 | | S30 | | | | | | BP7 | | S31 | | | | | Note 1: Circles indicate Schmitt trigger inputs. Note 2: LED direct drive is possible. Note 3: BP0-7 select V<sub>LC1</sub> as the input source. The output level changed by the external circuit of BP0-7 and V<sub>LC1</sub>. #### 10.5.2 Non-Port Pins | Pin | Input/Output | Serves as<br>Pin for | Functions | At Reset | I/O Circuit<br>Type (Note 1) | |------------------------------------|--------------|----------------------|-------------------------------------------------------------------------------------|----------|------------------------------| | TIO | Input | P13 | External event pulse input pin for timer/event counter. | | B-C | | PTO0 | Input/Output | P20 | Timer/event counter output pin. | Input | E-B | | PCL | Input/Output | P22 | Clock output pin. | Input | E-B | | BUZ | Input/Output | P23 | Fixed-frequency output pin (for buzzer or system clock trimming). | Input | E-B | | SCK | Input/Output | P01 | Serial clock input/output pin. | Input | Ē-A | | SO/SB0 | Input/Output | P02 | Serial data output pin. Serial bus input/output pin. | Input | (F)-В | | SI/SBI | Input/Output | P03 | Serial data input pin. Serial bus input/output pin. | Input | (M) -C | | INT4 | Input | P00 | Edge detector vector interrupt input pin (either rising or falling edge detection). | | B | | INT0 | Input | P10 | Edge detector interrupt input pin | | <b>B</b> -C | | INT1 | | P11 | (detected edge selectable). | | | | INT2 | Input | P12 | Edge detection testable input pin (rising edge detection). | | <b>B</b> -C | | KR0-KR3 | Input/Output | P60-P63 | Testable input/output pin (for falling edge detection). | Input | Ē-A | | KR4-KR7 | Input/Output | P70-P73 | Testable input/output pin (for falling edge detection). | Input | Ē-A | | S12-S23 | Output | | Segment signal output pin. | (Note 3) | G-A | | S24-S31 | Output | BP0-7 | Segment signal output pin. | (Note 3) | G -A | | COM0<br>-COM3 | Output | | Common signal output pin. | (Note 3) | G -B | | V <sub>LC0</sub> -V <sub>LC2</sub> | | | LCD drive power supply. | | | #### 10.5.2 Non-Port Pins | Pin | Input/Output | Serves as<br>Pin for | Functions | At Reset | I/O Circuit<br>Type (Note 1) | |-------------------|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------| | BIAS | | | Output pin for divided resistor cut externally installed. | Hi-Z | | | LCDCL<br>(Note 2) | Input/Output | P30 | Clock output pin for activating the externally extended driver. | Input | E-B | | SYNC<br>(Note 2) | Input/Output | P31 | Clock output pin for synchronizing the externally extended driver. | Input | E-B | | AN0-AN5 | Input | _ | 6-bit analog input pins to A/D converter. | | Υ | | AV <sub>REF</sub> | Input | _ | A/D converter reference voltage input pins. | | Z | | AV <sub>ss</sub> | | | A/D converter reference GND input pins. | | | | X1, X2 | Input | | Pin for connection of crystal/ceramics for main system clock generation. External clocks are input to X1, and their negative phase components are input to X2. | | | | XT1<br>XT2 | Input | | Pin for connection of crystals for sub-system clock generation. External clocks are input to XT1, and XT2 is disconnected. XT1 can also be used as a 1-bit input (test) pin. | | | | RESET | Input | | System reset input pin (low level active). | | В | | MD0-MD3 | Input/Output | P30-P33 | Mode selector pin for program memory (EPROM) write/verify operations. | Input | E-B | | V <sub>PP</sub> | | | Program voltage application pin for program memory (PROM) write/verify operations. V <sub>pp</sub> is normally connected to V <sub>DD</sub> . Connect to +12.5V for PROM write/verify operations. | | | | V <sub>D.D</sub> | | | Positive power supply pin. | | | | V <sub>ss</sub> | | | GND potential pin. | | | Note 1: Circles indicate Schmitt trigger inputs. Note 2: Pins for future use in system extention. Pins LCDCL and SYNC currently serve only as P30 and P31, respectively. Note 3: For each display output, the following V<sub>LCX</sub> are selected as input sources: S12-S31: V<sub>LC1</sub>, COM0-COM2: V<sub>LC2</sub>, COM3: V<sub>LC0</sub> However, the display output level varies depending on the display output and V<sub>LCX</sub> external circuit. Internal LCD split resistors are not included! ### Pin I/O configurations Following figures show the internal circuit configurations at the I/O ports. (1) Type A (part of Type E-B) This is a CMOS standard input buffer. (2) Type B This is a Schmitt trigger input with hysteresis characteristics. (3) Type B-C This is a Schmitt trigger input with hysteresis characteristics. (4) Type D (Part of Type E-B, F-A) This is a push-pull output that can be set to high impedance (with both P-ch and N-ch off). (5) Type E-B (6) Type F-A (7) Type F–B II-4-188 ## (8) Type G-A # (9) Type G-B #### (10) Type M-B ## (11) Type M-C (12) Type Y (from series resistor string voltage tap) (13) Type Z #### 10.6 DIFFERENCES BETWEEN μPD75P328GC AND μPD75328 Because the $\mu$ PD75P328GC is a product that incorporates an on-chip, writeable PROM in place of the masked ROM in the $\mu$ PD75328 program memory, the $\mu$ PD75P328GC and the $\mu$ PD75328 have similar hardware and perform similar CPU functions. They differ simply in their type of program memory and mask options. Tables 10.6-1 shows these differences. Refer to the $\mu$ PD75328 Users' Manual for details of hardware and CPU functions. Table 10.6-1 | Item | μPD75P328 | μPD75328 | |--------------------------------------------|------------------------------------------------------------------|--------------------------------------------------| | Program memory | • One-time PROM<br>• 8064 x 8 bits<br>• 0000H – 1F7FH | • Mask ROM<br>• 8064 x 8 bits<br>• 0000H – 1F7FH | | Port 4, 5 pull-up resistor | None | Mask option | | Split resistor to supply LCD driving power | None | Mask option | | Pin connection | V <sub>PP</sub> pin and one-time PROM program pins are included. | not available | | Operation supply voltage range | 5 V ± 5% | 2.7 to 6.0 V | | Package | 80-pin plastic QFP (bent lead) | | #### 10.7 One-Time PROM (Program Memory) Write and Verify Program memory contained in the µPD75P328 is one-time PROM (8064 x 8 bits) which can be electrically written. The pins listed in the table given below are used for one-time PROM write and verify. Address is update by clock input from the X1 pin instead of address input. Table 10.7-1 Pin function | Pin name | Function | |-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | X1, X2 | Address update clock during when PROM is write/verification is input to the X1 pin. Its inverted signal is input to the X2 pin. | | MD0-MD3 | Operation mode selection pins during PROM write/verification. | | P40-P43 (low-order four bits)<br>P50-P53 (high-order four bits) | 8-bit data input/output pins during PROM write/verified. | | V <sub>DD</sub> | Supply voltage apply pin. During the normal operation, 5 V $\pm$ 5 % is applied; during PROM write/verification, +6 V is applied. | | V <sub>PP</sub> | Voltage apply pin during PROM write/ verification. (Normally, V <sub>DD</sub> potential) | Caution 1: Handle the pins not used during program memory write and verify as follows: • Other than the XT2 pin: Connect to V<sub>SS</sub> via pull-down resistor. · XT2 pin: Do not connect the pin. Caution 2: The μPD75P328 does not have an erasion window, thus the program memory contents cannot be erased with ultraviolet rays. #### 10.7.1 Operating Mode during PROM is Write/Verification When +6 V and +12.5 V are applied to the $V_{DD}$ and $V_{pp}$ pins, respectively, of the $\mu$ PD75P328 the PROM write/verify mode is entered. The operation mode is selected according to the input signals to the MD0-MD3 pins as listed in Table 10.7-2. Pins not used in PROM function should be pulled to Vss. Table 10.7-2 Operating Mode | | Ор | erating mod | de specifica | tion | | Operation | |-----------------|------------------------------------|-------------|----------------|------|---|------------------------------| | V <sub>DD</sub> | DD V <sub>PP</sub> MD0 MD1 MD2 MD3 | | Operating mode | | | | | | | Н | L | Н | L | Clear program memory address | | +12.5 V | +6 V | L | Н | Н | Н | Write mode | | +12.5 V | +6 V | L | L | Н | Н | Verify mode | | | | Н | X | Н | Н | Program inhibit mode | Remarks: X: L or H #### 10.7.2 PROM Write Procedure PROM can be written at the high speed according to the following Procedure: - (1) Pull unused pins low to $V_{SS}$ with resistors. Set the X1 pin low. (2) Supply 5 V to the $V_{DD}$ and $V_{PP}$ pins. - (3) Wait for 10 us. - (4) Selected the clear program memory address mode. - (5) Supply +6 V and +12.5 V to the V<sub>DD</sub> and V<sub>PP</sub> pins. - (6) Select the program inhibit mode. - (7) Write data in the 1-ms write mode. - (8) Select the program inhibit mode. - (9) Select the verify mode. If the data is written normally, proceed to (10). If it is not written normally, repeat (7) to (9). - (10) Supply X (number of (7)-(9) repetitions) x 1 ms program pulses (additional write). - (11) Select the program inhibit mode. - (12) Input four pulses to the X1 pin to update the program memory address by one. - (13) Repeat (7)-(12) until the end address is reached. - (14) Select the clear program memory address mode. - (15) Change the V<sub>DD</sub>, V<sub>PP</sub> pin voltage to 5 V. (16) Turn off the power. Steps (2) to (12) are illustrated below: #### 10.7.3 PROM Read Procdure The PROM contents can be read according to the following procedure: - (1) Pull unused pins low to $V_{SS}$ with resistors. - Set the X1 pin low. - (2) Supply 5 V to the $V_{\rm DD}$ and $V_{\rm PP}$ pins. - (3) Wait for 10 us. - (4) Select the clear program memory address mode. - (5) Supply + 6 V and + 12.5 V to the $V_{DD}$ and $V_{PP}$ pins. - Select the program inhibit mode. - (7) Select the verify mode. Input four clock pulses to the X1 pin. The data are output from the memory addresses, one address at a time, in a cycle of hour clock pulses which are input to the X1 pin. - (8) Select the program inhibit mode. - (9) Select the clear program memory address mode. - (10) Change the V<sub>DD</sub>, V<sub>PP</sub> voltage to 5 V. (11) Turn off the power. Steps (2) to (12) are illustrated below: ## 10.8 Electrical characteristics #### Absolute Maximum Rating (Ta=25°C) | | | | Cond | dition | Rating | Unit | |---|-----------------------|-----------------------------|------------------|-----------------|------------------------------|------| | | | V <sub>DD</sub> | | | -0.3 to +7.0 | V | | | Supply voltage | V <sub>PP</sub> | | | -0.3 to +13.5 | V | | | | V <sub>11</sub> | Other than ports | 4 and 5 | -0.3 to V <sub>DD</sub> +0.3 | V | | | Input voltage | (Note 1)<br>V <sub>12</sub> | Ports 4 and 5 | Opendrain | -0.3 to +11 | v | | | Output voltage | V <sub>o</sub> | | | -0.3 to V <sub>DD</sub> +0.3 | V | | | High-level | | 1 pins | | -15 | mA | | | output current | I <sub>ОН</sub> | All other pins | | -30 | mA | | | | | 1 pins | Peak value | 30 | mA | | | | | pins | Effective value | 15 | mA | | - | Low-level | (Note 2) | Total of ports | Peak value | 100 | mA | | | output current | l <sub>OL</sub> | 0, 2, 3, 5 and 8 | Effective value | 60 | mA | | | | | Total of ports | Peak value | 100 | mA | | | | | 4, 6 and 7 | Effective value | 60 | mA | | | Operating temperature | T <sub>opt</sub> | | | -10 to +70 | °C | | | Storage temperature | T <sub>stg</sub> | | | -65 to +150 | °C | Note 1: When applying more than 10 volts to ports 4 or 5, the pull-up resistor must be 50K ohms min. 2: Effective value is obtained as follows: (Effective) value = (Peak value) x √duty cycle #### Main system clock Oscillator Characteristics $(Ta = -10 \text{ to } +70^{\circ}\text{C}, V_{DD} = 5V + /-5\%)$ | Resonator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-----------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|------|------| | Note 3<br>Ceramic<br>resonator | X1 X2 | Note 1<br>Oscillation<br>frequency (f <sub>XX</sub> ) | | 1.0 | | 5.0 | MHz | | | C1 C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization<br>time | When V <sub>DD</sub> reaches<br>the minimum<br>oscillator operating<br>voltage. | | | 4 | ms | | Crystal<br>resonator | X1 X2 | Note 1<br>Oscillation<br>frequency (f <sub>XX</sub> ) | | 1.0 | 4.19 | 5.0 | MHz | | | C1 C2 V <sub>DD</sub> | Note 2<br>Oscillation<br>stabilization<br>time | | | | 10 | ms | | External clock | X1 X2 | Note 1<br>X1 input<br>frequency (f <sub>X</sub> ) | | 1.0 | | 5.0 | MHz | | | μPD74HCU04 | X1 input high/<br>low level<br>width (t <sub>XH</sub> / t <sub>XL</sub> ) | | 100 | | 500 | ns | - Note 1: The oscillation frequency and X1 input frequency values indicated in this table express only the characteristics of the oscillator. Therefore, refer to the AC characteristics for the instruction execution time. - Oscillation stabilization time is defined as the time needed for the oscillator to stabilize after V<sub>DD</sub> is applied or after the STOP mode is released. - 3: The following ceramic and crystal oscillators are recommended for the µPD75P328GC. #### **Recommended Ceramic Resonators** | Manufactura | Dundust | External cap | acitance (pF) | Operating voltage range (V) | | | |-------------|-------------|----------------------------------|----------------------------------|-----------------------------|------|--| | Manufacture | Product | C1 | C2 | MIN. | MAX. | | | MURATA | CSA 2.00MG | 30 | 30 | 4.75 | 5.25 | | | | CSA 4.19MG | 30 | 30 | 4.75 | 5.25 | | | | CSA 4.19MGU | 30 | 30 | 4.75 | 5.25 | | | | CST 4.19MG | 30pF<br>(internally<br>provided) | 30pF<br>(internally<br>provided) | 4.75 | 5.25 | | # Subsystem Clock Oscillator Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V+/-5%) | Resonator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |-------------------|-----------------------------|-----------------------------------------------------------------------------|---------------------------|------|--------|------|------| | Crystal resonator | [XT1 XT2]<br>— ξ330 κΩ | Oscillation<br>frequency<br>(f <sub>XT</sub> ) | | 32 | 32.768 | 35 | kHz | | | 22 pF 33 pF V <sub>DD</sub> | | V <sub>DD</sub> =4.5~6.0V | | 1.0 | 2 | s | | External<br>clock | XT1 XT2 Open | XT1 input<br>frequency<br>(f <sub>XT</sub> ) | | 32 | | 100 | kHz | | | <u> </u> | XT1 input high/<br>low level width<br>(t <sub>XTH</sub> /t <sub>XTL</sub> ) | | 5 | | 15 | μs | # Capacitance (Ta =25°C, $V_{DD}$ =0V) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------|------------------|------------------------------------------------------------|------|------|------|------| | Input capacitance | C <sub>IN</sub> | f=1 MHz | | | 15 | pF | | Output capacitance | C <sub>OUT</sub> | Voltage should not be applied to any pin except those used | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | for measurements. | | | 15 | pF | # DC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V±5%) | Parameter | Symbol | Cond | lition | MIN. | TYP. | MAX. | Unit | |--------------------------|-------------------|----------------------------------|--------------------------------------|----------------------|-----------------|--------------------|------| | | V <sub>IH1</sub> | Port 2, 3 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | | High-level | V <sub>IH2</sub> | Port 0, 1, 6, 7, RESET | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | | | input voltage | V <sub>IH3</sub> | Port 4, 5 Open-drain | | 0.7V <sub>DD</sub> | | 10 | V | | | V <sub>IH4</sub> | X1, X2, XT1 | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | V | | | V <sub>IL1</sub> | Port 2, 3, 4, 5, 8 | | 0 | - | 0.3V <sub>DD</sub> | V | | Low-level input voltage | V <sub>IL1</sub> | Port 0, 1, 6, 7, RESET | | 0 | | 0.2V <sub>DD</sub> | V | | | V <sub>IL3</sub> | X1, X2, XT1 | , | 0 | | 0.4 | V | | High-level | V <sub>OH1</sub> | Port 0, 2, 3, 6, 7, 8 BIAS | I <sub>OH</sub> =-1mA | V <sub>DD</sub> -1.0 | | | V | | output voltage | V <sub>OH2</sub> | BPO-7 | I <sub>OH</sub> =-100μA<br>Note 4 | V <sub>DD</sub> -2.0 | - | | V | | | V <sub>OL1</sub> | Port 0, 2, 3, 4, 5, 6, 7,8 | Port 3, 4, 5 I <sub>OL</sub> =15mA | | 0.4 | 2.0 | V | | | | | I <sub>OL</sub> =1.6mA | | | 0.4 | V | | Low-level output voltage | V <sub>OL2</sub> | SB0, 1 open-drain | Pull-up resistor<br>(R) =1k ohm min. | | | 0.2V <sub>DD</sub> | V | | | V <sub>OL3</sub> | BP0-7 | I <sub>OL</sub> =100μA<br>Note 4 | | | 1.0 | ٧ | | High-level | I <sub>LIH1</sub> | V <sub>IN</sub> =V <sub>DD</sub> | Other than X1, X2, and XT1 pins | | | 3 | μΑ | | input leakage<br>current | I <sub>LIH2</sub> | 11 <b>4</b> DD | X1, X2, XT1 | | | 20 | μΑ | | | I <sub>LIH3</sub> | V <sub>IN</sub> =10V | Port 4, 5 | | | 20 | μA | ## DC Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V±5%) | Parameter | Symbol | Cond | lition | MIN. | TYP. | MAX. | Unit | |-----------------------------------------------------|-------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------|-----------------|------| | Low-level input leakage | I <sub>LIL1</sub> | V <sub>IN</sub> =0V | Other than X1, X2, and XT1 pins | - 12 · · · · · · · · · · · · · · · · · · | | -3 | μΑ | | current | I <sub>LIL2</sub> | "" | X1, X2, XT1 | | | -20 | μА | | High-level output leakage | I <sub>LOH1</sub> | V <sub>OUT</sub> =V <sub>DD</sub> | Other than ports<br>4 and 5 | 41. | | 3 | μΑ | | current | I <sub>LOH2</sub> | V <sub>OUT</sub> =10V | Port 4,5 | | | 20 | μA | | Low-level<br>output leakage<br>current | I <sub>LOL</sub> | V <sub>OUT</sub> =0V | | | | <b>-3</b> | μΑ | | Internal<br>pull-up<br>resistor | R <sub>LI</sub> | Port 0, 1, 2, 3, 6, 7,8 (ex | ccept P00) V <sub>IN</sub> =0V | 15 | 40 | 80 | kΩ | | LCD drive voltage | V <sub>LCD</sub> | | | 2.5 | | V <sub>DD</sub> | V | | LCD output vol-<br>tage deviation<br>(Common) N. 7 | Vonc | I <sub>O</sub> = ± 5 μA | V <sub>LCD0</sub> =V <sub>LCD</sub><br>V <sub>1000</sub> =V <sub>100</sub> x2/3 | 0 | | ±0.2 | ٧ | | LCD output vol-<br>tage deviation<br>(Segment) N. 7 | V <sub>ods</sub> | I <sub>O</sub> = ± 1 μA | $\begin{array}{l} V_{LCD0} = V_{LCD} \\ V_{LCD1} = V_{LCD} \times 2/3 \\ V_{LCD2} = V_{LCD} \times 1/3 \\ 2.7 \ V \le V_{LCD} \le V_{DD} \end{array}$ | 0 | | ±0.2 | V , | | Common<br>output<br>impedance | R <sub>сом</sub> | Note 3 | | | 3 | 6 | kΩ | | Segment<br>output<br>impedance | R <sub>s</sub> | Note 3 | | 4 - 9 | 15 | 20 | kΩ | | | I <sub>DD1</sub> | Note 5<br>4.19 MHz crystal | Note 2 | | 5 | 15 | mA | | Note 1 | I <sub>DD2</sub> | oscillation C1=C2=22pF | HALT mode | | 500 | 1500 | μΑ | | Supply | | Note 6<br>32kHz crystal | | | 350 | 1000 | μА | | current | DD3 | oscillation | HALT mode | | 35 | 100 | μΛ | | | I <sub>DD4</sub> | XT1 =0V STOP mode | - | | 0.5 | 20 | μΑ | Note 1. The current drained through the internal pull-up resistors is not included. - 2. When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. - 3. 2.5V ≤ V<sub>LCD</sub> ≤ V<sub>DD</sub> 4. When any two pins of BP0 to BP3 and any two pins of BP4 to BP7 are used simultaneously for output. - 5. Including the subsystem clock power consumption. - 6. When system clock control register (SCC) is set to 1001; main system clock's oscillation halted once sub-system clock - 7. Voltage deviation shows differences between the expected values ( $V_{LCDn}$ ; n = 0, 1, 2) of the segment and common output and output voltage. A/D Converter Characteristics (Ta =-10 to +70°C, $V_{DD}$ =5V±5%, $AV_{SS}$ = $V_{SS}$ = 0V) | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |---------------------------|-------------------|---------------------------------------------|------------------|------|--------------------|------| | Resolution | | | 8 | 8 | 8 | bit | | Absolute accuracy *1 | | 2.5 V ≤ V <sub>AREF</sub> ≤ V <sub>DD</sub> | | | ±1.5 | LSB | | Conversion time | t <sub>CONV</sub> | *2 | | | 168/f <sub>X</sub> | s | | Sampling time | t <sub>SAMP</sub> | *3 | | | 44/f <sub>X</sub> | s | | Analog input voltage | V <sub>IAN</sub> | | AV <sub>ss</sub> | | VAREF | V | | Analog input impedance | R <sub>AN</sub> | | | 1000 | | ΜΩ | | V <sub>AREF</sub> current | V <sub>AREF</sub> | | | 1.0 | 2.0 | mA | <sup>\*1:</sup> Absolute accuracy except for quantization error (±1/2 LSB). AC Characteristics (Ta =-10 to $+70^{\circ}$ C, $V_{DD} = 5V \pm 5\%$ ) Operation other than serial transfer operation | | 1, - 00 | | | <del></del> | | | |-------------------------------------------------|-------------------------------------|---------------------------------|--------|-------------|------|------| | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | | Note 1 | | Operated with main system clock | 0.95 | | 64 | μs | | Cycle time (minimum instruction execution time) | CY | Operated with sub-system clock | 114 | 122 | 125 | μs | | TI0 input frequency | f <sub>TI</sub> | | 0 | | 1 | MHz | | TIO input high/low level width | t <sub>TIH</sub> , t <sub>TIL</sub> | | 0.48 | | | μs | | Interrupt input | + + | INT0 | Note 2 | | | μs | | high/low level width | INTH' INTL | KR0-7, INT1 2, 4 | 10 | | | μs | | RESET low level width | t <sub>BSL</sub> | | 10 | | | μs | # Note 1. Cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure to the right shows the $V_{\rm DD}$ supply voltage vs. cycle time ( $t_{\rm CY}$ ) characteristic when operated with the main system clock. 2. Either 2t<sub>CY</sub> or 64/f<sub>XX</sub> can be selected by setting the interrupt mode register (IM0). ## **Serial Transfer Operation** 2-line/3-line serial I / 0 mode (SCK....Internal clock output) | - more more contain, a more (containment) | | | | | | | | | | | | |-------------------------------------------|--------------------------------------|-----------|-----------------------------|------|------|------|--|--|--|--|--| | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | | | | | | | SCK cycle time | t <sub>KCY1</sub> | Output | 1600 | | - | ns | | | | | | | SCK high / low level width | t <sub>KL1</sub><br>t <sub>KH1</sub> | Output | t <sub>KCL1</sub> /2<br>-50 | | | ns | | | | | | | SI set-up time (against SCK) | t <sub>SIK1</sub> | | 150 | | | ns | | | | | | | SI hold time (against SCK ) | t <sub>KSI1</sub> | | 400 | | | ns | | | | | | | SCK S0 output delay time | t <sub>KSO1</sub> | | | | 250 | ns | | | | | | <sup>\*2:</sup> Tme to EOC = 1 after conversion start instruction execution (40.1 $\mu$ s when $f_\chi$ = 4.19 MHz) \*3: Time to sampling end after conversion start instruction execution (10.5 $\mu$ s when $f_\chi$ = 4.19 MHz) # 2-line / 3-line serial I/0 mode (SCK....External clock input) : | Parameter | Symbol | Condition | | MIN. | TYP. | MAX. | Unit | |-------------------------------|--------------------------------------|-----------|-------|------|------|------|------| | SCK cycle time | t <sub>KCY2</sub> | | Input | 800 | | | ns | | SCK high / low level width | t <sub>KL2</sub><br>t <sub>KH1</sub> | | Input | 400 | | | ns | | SI set-up time (against SCK ) | t <sub>SIK2</sub> | | | 100 | | | ns | | SI hold time (against SCK 1) | t <sub>KSI2</sub> | | | 400 | | | ns | | SCK - S0 output delay time | t <sub>KSO2</sub> | | | ÷ | | 300 | ns | ## SBI Mode (SCK....Internal clock output Master)): | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------|--------------------------------------|-----------|----------------------------|------|------|------| | SCK cycle time | t <sub>KCY3</sub> | | 1600 | | | ns | | SCK high / low level width | t <sub>KL3</sub><br>t <sub>KH3</sub> | | t <sub>KCY</sub> /2<br>-50 | | | ns | | SB0, SB1 set-up time (against SCK†) | t <sub>SIK3</sub> | | 150 | | | ns | | SB0, SB1 hold time (against SCK†) | t <sub>KSI3</sub> | | t <sub>KCY</sub> /2 | | | ns | | SCK ← SB0, SB1 output delay time | t <sub>KSO3</sub> | | 0 | | 250 | ns | | SCK - SB0, SB1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1↓ — SCK↓ | t <sub>sbK</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 high level width | t <sub>SBH</sub> | | t <sub>KCY</sub> | | | ns | #### SBI Mode (SCK.... External clock input (Slave)): | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-------------------------------------|--------------------------------------|-----------|---------------------|------|------|------| | SCK cycle time | t <sub>KCY4</sub> | | 800 | | | ns | | SCK high / low level width | t <sub>KL4</sub><br>t <sub>KH4</sub> | | 400 | | - | ns | | SB0, SB1 set-up time (against SCK ) | t <sub>SIK4</sub> | | 100 | | | ns | | SB0, SB1 hold time (against | t <sub>KSI4</sub> | | t <sub>KCY</sub> /2 | | | ns | | SCK - SB0, SB1 output delay time | t <sub>KSO4</sub> | | 0 | | 300 | ns | | SCK - SB0, SB1 | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 + SCK + | t <sub>sbK</sub> | · | t <sub>KCY</sub> | | | ns | | SB0, SB1 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0, SB1 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1, XT1 input) Clock Timing **TIO Timing** Serial Transfer Timing 3-line serial I/O mode # **Serial Transfer Timing** (SBI mode) Bus release signal transfer: Interrupt input timing RESET input timing #### Data Memory STOP Mode Low Supply Voltage Data Retention Characteristic (Ta = -10 to +70 °C) | Parameter | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------------------|-------------------|------------------------------|------|---------------------------------|------|------| | Data retention supply voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention supply current (Note1) | I <sub>DDDR</sub> | V <sub>DDDR</sub> = 2.0V | | 0.1 | 10 | μΑ | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | Oscillation atabilization weit time | | Release by RESET input | | 2 <sup>17</sup> /f <sub>X</sub> | | ms | | Oscillation stabilization wait time (Note 2) | TWAIT | Release by interrupt request | | Note 3 | | ms | Note 1: The current drained through the internal pull-up resistor is not included Note 2: The oscillation stabilization wait time is used to prevent unstable CPU operation at the beginning of oscillator operation, during which CPU operation is disabled. Note 3: This value depends on the setting of the basic interval timer mode register (BTM). (Refer to the table below.) | втмз | BTM2 | BTM1 | втмо | WAIT time Parantheses ( ) indicates $f_{\chi}$ =4.19MHz | |------|------|------|------|---------------------------------------------------------| | _ | 0 | 0 | 0 | 2 <sup>20</sup> /f <sub>X</sub> (Approximately 250 ms) | | _ | 0 | 1 | 1 | 2 <sup>17</sup> /f <sub>X</sub> (Approximately 31.3 ms) | | _ | 1 | 0 | 1 | 2 <sup>15</sup> /f <sub>X</sub> (Approximately 7.82 ms) | | _ | 1 | 1 | 1 | 2 <sup>13</sup> /f <sub>X</sub> (Approximately 1.95 ms) | Data Retention Timing (Releasing STOP mode by RESET) Data Retention Timing (Standby release signal: Releasing STOP mode by interrupt signal) DC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) | Item | Symbol | Test Conditions | MIN. | TYP. | MAX. | Unit | |--------------------------------------|------------------|------------------------------------------------------|----------------------|------|---------------------|------| | High level input voltage | V <sub>IH1</sub> | Other than X1, X2 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | | V <sub>IH2</sub> | X1, X2 | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | ٧ | | Low level input voltage | V <sub>IL1</sub> | Other than X1, X2 | 0 | | 0.3 V <sub>DD</sub> | ٧ | | | V <sub>IL2</sub> | X1, X2 | 0 | | 0.4 | ٧ | | Input leak current | I <sub>LI</sub> | V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | | | 10 | μΑ | | High level output voltage | V <sub>OH</sub> | I <sub>OH</sub> = -1 mA | V <sub>DD</sub> -1.0 | | | V | | Low level output voltage | V <sub>OL</sub> | I <sub>OL</sub> = 1.6 mA | | | 0.4 | V | | V <sub>DD</sub> power supply current | I <sub>DD</sub> | | | | 30 | mA | | V <sub>PP</sub> power supply current | l <sub>PP</sub> | $MD0 = V_{IL}, MD1 = V_{IH}$ | | | 30 | mA | Note 1: Ensure that $V_{pp}$ does not exceed +13.5V including overshoot. Note 2: Ensure that $V_{DD}$ is applied before $V_{pp}$ , and is turned off after $V_{pp}$ . # AC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) | ltem | Symbol | Note 1 | Test Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|----------------------------------|------------------|----------------------------------|-------|------|------|------| | Address setup time (Note 2) (to MD0 ) | t <sub>AS</sub> | t <sub>AS</sub> | | 2 | | | μs | | MD1 setup time (to MD0 ↓ ) | t <sub>M1S</sub> | t <sub>OES</sub> | | 2 | | | μs | | Data setup time (to MD0 ↓ ) | t <sub>DS</sub> | t <sub>DS</sub> | | 2 | | | μs | | Address hold time (Note 2) (to MD0 † ) | t <sub>AH</sub> | t <sub>AH</sub> | | 2 | | | μs | | Data hold time (to MD0 ) | t <sub>DH</sub> | t <sub>DH</sub> | | 2 | | | μs | | MD0 | t <sub>DF</sub> | t <sub>DF</sub> | | 0 | | 130 | ns | | V <sub>PP</sub> setup time (to MD3 ∤ ) | t <sub>VPS</sub> | t <sub>vps</sub> | | 2 | | | μs | | V <sub>DD</sub> setup time (to MD3 ↑ ) | t <sub>vDS</sub> | t <sub>vcs</sub> | | 2 | | | μs | | Initial program pulse width | t <sub>PW</sub> | t <sub>PW</sub> | | 0.95 | 1.0 | 1.05 | ms | | Additional program pulse width | t <sub>OPW</sub> | t <sub>OPW</sub> | | 0.95 | | 21.0 | ms | | MD0 setup time (to MD1 ) | t <sub>mos</sub> | t <sub>CES</sub> | | 2 | | | μs | | MD0 data output delay time | t <sub>DV</sub> | t <sub>DV</sub> | MD0 = MD1 = V <sub>IL</sub> | | | 1 | μs | | MD1 hold time (to MD0 ) | t <sub>M1H</sub> | t <sub>OEH</sub> | $t_{M1H} = t_{M1R} \ge 50 \mu s$ | 2 | | | μs | | MD1 recovery time (to MD0 ) | t <sub>M1R</sub> | t <sub>OR</sub> | | 2 | | | μs | | Program Counter reset time | t <sub>PCR</sub> | _ | | 10 | | | μs | | X1 input high/low level width | t <sub>xH</sub> ,t <sub>xL</sub> | | | 0.125 | | | μs | | X1 input frequency | f <sub>X</sub> | | | | | 4.19 | MHz | | Initial mode setting time | t <sub>i</sub> | | | 2 | | | μs | | MD3 setup time (to MD1 ) | t <sub>M3S</sub> | | | 2 | | | μs | # AC Programming Characteristics (Ta = 25 °C, $V_{DD}$ = 6.0 $\pm$ 0.25V, $V_{PP}$ = 12.5 $\pm$ 0.3V, $V_{SS}$ = 0V) (cont'd) | Item | Symbol | Note 1 | Test Conditions | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|------------------|----------------------------|------|------|------|------| | MD3 hold time (to MD1 ) | t <sub>мзн</sub> | _ | | 2 | | | μs | | MD3 setup time (to MD0 ) | t <sub>M3SR</sub> | _ | For program<br>memory read | 2 | | | μs | | Address (Note 2) data output delay time | t <sub>DAD</sub> | t <sub>ACC</sub> | For program<br>memory read | 2 | | | μs | | Address (Note 2) data output hold time | t <sub>HAD</sub> | t <sub>oн</sub> | For program<br>memory read | 0 | | 130 | ns | | MD3 hold time (to MD0 ) | t <sub>M3HR</sub> | = | For program<br>memory read | 2 | | | μs | | MD3 - data output float delay time | t <sub>DFR</sub> | | For program<br>memory read | 2 | | | μs | Note 1: Symbol for corresponding $\mu PD27C256$ . Note 2: The internal address signal is incremented by 1 by the rise of the 4th X1 input, and is not connected to a pin. #### Program Memory Write Timing ## Program Memory Read Timing 11-4-209 ### CHAPTER 5 $\mu$ COM-75X FAMILY STANDARD INSTRUCTION SET #### 1. FEATURED INSTRUCTIONS The $\mu$ COM-75x standard instruction set is an improvement of the instruction set for the $\mu$ PD7500-series, which is the predecessor of the $\mu$ COM-75X family. - It is a new epoch-making instruction set that maintains compatibility with the μPD7500 series, and has the following features: - (1) Bit manipulation instructions for various applications - (2) Efficient 4-bit manipulation instructions - (3) 8-bit manipulation instructions comparable to 8-bit microcomputer instructions - (4) GETI instruction to reduce program size - (5) String effect instructions and base correction instructions to raise program efficiency - (6) Table reference instructions appropriate for consecutive reference - (7) 1-byte relative branch instructions - (8) Easy-to-understand and well arranged NEC standard mnemonics #### 1.1 GETI instruction The GETI instruction is provided to convert into 1-byte instructions: - (a) Subroutine call instructions - (b) Branch instructions to all spaces - (c) Any desired 2-byte, 2-machine-cycle instruction (except BRCB or CALLF instruction) - (d) Pair of two 1-byte instructions. When the GETI instruction is executed, the table at program memory addresses 0020H - 007FH is referenced, and the referenced 2-byte data is executed as one of the instruction (a) - (d) Thus, 48 instructions of the (a) - (d) category can be converted into 1-byte instructions. If frequently used (a) - (d) instructions are converted into 1-byte instructions by using the GETI instruction, the number of program bytes can be drastically reduced. #### 1.2 Bit manipulation instructions Bit manipulation can be performed by using the following instructions: | | • • • • • | | | • | |-------|--------------------|---|---------------------|----------------------------------------------| | (i) | Bit setting | : | SET1<br>SET1 | mem.bit<br>mem.bit* | | (ii) | Bit clear | : | CLR1<br>CLR1 | mem.bit<br>mem.bit* | | (iii) | Bit test | : | SKT<br>SKT | mem.bit<br>mem.bit* | | (iv) | Bit test | : | SKF<br>SKF | mem.bit<br>mem.bit* | | (v) | Bit test and clear | : | SKTCLR | mem.bit* | | (vi) | Boolean operations | : | AND1<br>OR1<br>XOR1 | CY, mem.bit*<br>CY, mem.bit*<br>CY, mem.bit* | The mem.bit\* is a bit address indicated by bit manipulation addressing (fmem. bit, pmem. @ L, @ H + mem. bit). All these bit manipulation instructions are always applicable to input/output ports; therefore, the input/output ports can be handled very efficiently. #### 1.3 String effect instructions The instruction set provides the following two types of string effect instructions: (a) MOV A, #n4 or MOV XA, #n8 (b) MOV HL, #n8 "String effect" places these instructions at contiguous addresses. Example: A0 : MOV A, #0 A1 : MOV A, #1 XA7 : MOV XA, #07 If the string effect instructions are placed as in this example, when the first execution address is A0, the following two instructions are replaced with NOP instructions for execution; when the first address is A1, the following one instruction is replaced with a NOP instruction for execution. That is, only the first executed instruction is valid, and all string effect instructions following are handled as NOP instructions. The string effect instructions enable efficient constant loading into a given accumulator (A register, register pair XA) and data pointer (register pair HL). #### 1.4 Base correction instructions Depending on the application, the result of 4-bit data addition or subtraction (made in binary) must be converted into a decimal number or subjected to sixenary correction, as with the time of day. Thus, the $\mu$ COM-75x standard instruction set contains base correction instructions to correct the result of 4-bit data addition or subtraction to any desired base number. (a) Base correction during addition Assume that the correction base value is m. By using the combination of ADDS A, #16-m ADDC A, @ HL; A, C — A + (HL) + C ADDS A, #m the accumulator and memory (HL) contents are added together, and the addition result is subjected to m correction. Overflow is left in the carry flag. If a carry results from execution of the ADDC A, @ HL instruction, the following ADDS A, #n4 instruction is skipped. If no carry results, the ADDS A, # n4 instruction is executed. At this time, the skip function for this instruction is inhibited; even if a carry results from the addition, the following instruction will not be skipped. Therefore, the program can be written following the ADDS A, #n4 instruction. Example: To add the accumulator and memory together in decimal. (b) Base correction during subtraction Assume that the correction base value is m. By using the combination of SUBC A, @ HL ADDS A, #m memory (HL) is subtracted from the accumulator, and the result is subjected to m correction. Underflow is left in carry flag. If a borrow does not result from execution of the SUBC A, @ HL instruction, the following ADDS A, #n4 instruction is skipped. If a borrow results, the ADDS A, #n4 instruction is executed. At this time, the skip function of this instruction is inhibited; even if a carry results from the addition, the following instruction will not be skipped. Therefore, the program can be written following the ADDS A, #n4 instruction. #### 1.5 Skip instruction and number of machine cycles required for skip The $\mu\text{COM-}75x$ standard instruction set contains the skip function involved in condition decision. If the skip condition is satisfied when a skip instruction (instruction having the skip condition) is executed, the skip function skips the next instruction and executeds the instruction following the skipped instruction. When a skip occurs, the number of machine cycles required for the skip is - (a) Two machine cycles if the skipped instruction following the skip instruction is a 3-byte instruction (BR laddr or CALL laddr). - (b) One machine cycle when the skipped instruction is not listed in (a) above. #### 2. Instruction Set and Operations (1) Operand representation format and description method In the operand field of each instruction, enter the operand according to the description method for the instruction operand representation format (details are based on the assembler specifications). When more than one entry exits under the description method, select one of the entries. The uppercase alphabetic characters and the symbols + and - are keywords which must be entered exactly as shown. For immediate data, enter the proper numeric value or label. The register and flag abbreviations shown in Figure 2.3-1 can be entered as labels instead of mem, fmem, pmem, bit, etc., (however, labels that can be entered instead of fmem or pmem are limited). | Representation format | Description method | |-----------------------|--------------------------------------------------------------------------------| | reg | X, A, B, C, D, E, H, L | | reg1 | X, B, C, D, E, H, L | | rp | XA, BC, DE, HL | | rp1 | BC, DE, HL | | rp2 | BC, DE | | rpa | HL, DE, DL | | rpa1 | DE, DL | | n4 | 4-bit immediate data or label | | n8 | 8-bit immediate data or label | | mem | 8-bit immediate data or label* | | bit | 2-bit immediate data or label | | fmem<br>pmem | FB0H-FBFH, FF0H-FFFH immediate data or label FC0H-FFFH immediate data or label | | addr | 0000H-3F7FH immediate data or label (Note) | | caddr | 12-bit immediate data or label | | faddr | 11-bit immediate data or label | | taddr | 20H-7FH immediate data (where bit 0 = 0) or label | | PORTn | PORT, n = number of port | | IEXXX | Interrupt enable flags, XXX specifies the interrupt sorce | | MBn | MB0, MB1, MB15 | <sup>\*</sup> For 8-bit data processing, only even addresses can be specified. Note: Depends of ROM size. # (2) Legend in explanation of operation A : A register, 4-bit accumulator B : B register, C : C register, D : D register, E : E register, H : H register, L : L register, X : X register, XA : XA register, pair, 8-bit accumulator BC : BC register pair BC : BC register pair DE : DE register pair HL : HL register pair DL : DL register pair PC : Program counter SP : Stack pointer CY : Carry flag, bit accumulator PSW : Program status word MBE : Memory bank enable flag MBS : Memory bank enable flag PORTn : Port n (n = number of port) IME : Interrupt master enable flag IExxx : Interrupt enable flag, xxx specifies the interrupt source PCC : Processor clock control register • : Separation between address and bit (xx) : Contents addressed by xx xxH : Hexadecimal data #### (3) Explanation of symbols under the "addressing area" column Remarks 1: MB indicates memory bank that can be accessed. 2: in \*2, MB = 0 independently of how MBE and MBS are set. 3: In \*4 and \*5, MB = 15 independently of how MBE and MBS are set. 4: \*6 to \*10 indicate the areas that can be accessed. (4) Explanation of the column number of machine cycles S denotes the number of machine cycles required by skip operation. The value of S varies as follows: - When no skip is made: S = 0 - When the skipped instruction is a 1- or 2-byte instruction: S = 1 - When the skipped instruction is a 3-byte instruction (BR laddr or CALL laddr) : S = 2 Caution: The GETI instruction is skipped in one machine cycle. One machine cycle is equal to one cycle of CPU clock $\Phi$ . The time can be selected from among three types by setting PCC. <sup>\*</sup> Depends of ROM size. | Instruction group | Mnemonic | Operand | Number<br>of<br>bytes | Number of machine cycles | Operation | Addressing area | Skip condition | |-----------------------|----------|------------|-----------------------|--------------------------|--------------------------------------------|-----------------|-----------------| | | | A, #n4 | 1 | 1 | A n4 | | String effect A | | | | reg1, #n4 | 2 | 2 | regl - n4 | | | | | | XA, #n8 | 2 | 2 | XA - n8 | | String effect A | | | | HL, #n8 | 2 | 2 | HL <del>→</del> n8 | 1 | String effect B | | | | rp2, #n8 | 2 | 2 | rp2 <del></del> | | | | | | A, @ HL | 1 | 1 | A <del>→</del> (HL) | *1 | | | | | A, @ rpa1 | 1 | 1 | A→ (rpa1) | *2 | | | | | XA, @ HL | 2 | 2 | XA - (HL) | *1 | | | | | @ HL, A | 1 | 1 | (HL) - A | *1 | | | | MOV | @ HL, XA | 2 | 2 | (HL) - XA | *1 | | | | | A, mem | 2 | 2 | A - (mem) | *3 | | | | | XA, mem | 2 | 2 | XA- (mem) | *3 | | | | | mem, A | 2 | 2 | (mem) - A | *3 | | | Transfer | | mem, XA | 2 | 2 | (mem) XA | *3 | | | instruction | | A, reg1 | 2 | 2 | A <del>→</del> reg1 | | | | | | XA, rp | 2 | 2 | XA <del></del> rp | <u> </u> | | | | | reg1, A | 2 | 2 | reg1— A | | | | | | rp1, XA | 2 | 2 | rp1 - A | | | | | | A, @ HL | 1 | - 1 | A→→ (HL) | *1 | | | | | A, @ rpa1 | 1 | 1 | A (rpa1) | *2 | | | | хсн | XA, @ HL | 2 | 2 | XA (HL) | *1 | | | | | A, mem | 2 | 2 | A → (mem) | *3 | | | | | XA, mem | 2 | 2 | XA (mem) | *3 | | | | | A, reg1 | 1 | 1 | A → reg1 | | | | | | XA, rp | 2 | 2 | XA rp | <b>†</b> | | | | | XA, @ PCDE | 1 | 3 | XA (PC <sub>13-8</sub> +DE) <sub>ROM</sub> | | | | | MOVT | XA, @ PCXA | 1 | 3 | XA (PC <sub>13-8</sub> +XA) <sub>ROM</sub> | † | | | | ADDS | A, #n4 | 1 | 1+S | A - A+n4 | 1 | carry | | | | A, @ HL | 1 | 1+S | A → A+(HL) | *1 | carry | | | ADDC | A, @ HL | 1 | 1 | A, CY- A + (HL) + CY | *1 | | | | SUBS | A, @ HL | 1 | 1+S | A A - (HL) | *1 | borrow | | | SUBC | A, @ HL | 1. | 1 | A, CY A - (HL) - CY | *1 | | | Operation instruction | AND | A, #n4 | 2 | 2 | A→ A∧ n4 | | | | man uction | | A, @ HL | 1 | 1 | A → A ∧ (HL) | *1 | | | | OR | A, #n4 | 2 | 2 | A → AV n4 | | | | | | A, @ HL | 1 | 1 | A → A∨ (HL) | *1 | | | | XOR | A, #n4 | 2 | 2 | A → A₩ n4 | | | | | | A, @ HL | 1 | 1 | A → A → (HL). | *1 | | # STANDARD INSTRUCTION SET | Instruction<br>group | Mnemonic | Operand | Number<br>of<br>bytes | Number of machine cycles | Operation | Addressing area | Skip condition | |-----------------------------|----------|---------------|-----------------------|--------------------------|----------------------------------------------------------------------|-----------------|----------------| | Accumu-<br>lator | RORC | Α | - 1 | 1 | $CY - A_0, A_3 - CY, A_{n-1} - A_n$ | | | | handling | NOT | Α | 2 | 2 | A <del></del> ⊼ | | | | | INCS | reg | 1 | 1+S | reg - reg +1 | | reg = 0 | | Increment and | | @ HL | 2 | 2+S | (HL) - (HL) +1 | . *1 | (HL) = 0 | | decrement | | mem | 2 | 2+S | (mem) - (mem) +1 | *3 | (mem) = 0 | | instructions | DECS | reg | 1 | 1+S | reg - reg - 1 | | reg = FH | | | SKE | reg, #n4 | 2 | 2+S | Skip if reg = n4 | | reg = n4 | | Comparison | | @ HL, #n4 | 2 | 2+S | Skip if (HL) = n4 | *1 | (HL) = n4 | | instructions | | A, @ HL | 1 . | 1+S | SKip if A = (HL) | *1 | A = (HL) | | | | A, reg | 2 | 2+S | Skip if A = reg | | A = reg | | | SET1 | CY | 1 | 1 | CY - 1 | | | | Carry flag<br>handling | CLR1 | CY | 1 | 1 | CY - 0 | | | | instructions | SKT | CY | 1 | 1+S | Skip if CY = 1 | | CY = 1 | | | NOT1 | CY | 1 | 1 | CY <del>→</del> CY | | | | | SET1 | mem.bit | 2 | 2 | (mem.bit) - 1 | *3 | | | | | fmem.bit | 2 | 2 | (fmem.bit) - 1 | *4 | | | | | pmem.@L | 2 | 2 | (pmem <sub>7-2</sub> +L <sub>3-2</sub> .bit(L <sub>1-0</sub> ) ) -1 | *5 | | | | | @ H + mem.bit | 2 | 2 | (H + mem <sub>3-0</sub> .bit) | *1 | | | | CLR1 | mem.bit | 2 | 2 | (mem.bit) - 0 | *3 | | | | | fmem.bit | 2 | 2 | (fmem.bit) - 0 | *4 | | | | | pmem.@ L | 2 | 2 | (pmem <sub>7-2</sub> +L <sub>3-2</sub> .bit (L <sub>1-0</sub> ) ) -0 | *5 | | | | | @ H + mem.bit | 2 | 2 | (H + mem <sub>3-0</sub> .bit) →0 | *1 | | | | SKT | mem.bit | 2 | 2+S | Skip if (mem.bit) = 1 | *3 | (mem.bit) = 1 | | Memory bit | | fmem.bit | 2 | 2+S | Skip if (fmem.bit) = 1 | *4 | (fmem.bit) = 1 | | manipulation<br>instruction | | pmem.@L | 2 | 2+S | Skip if $(pmem_{7.2} + L_{3.2}.bit (L_{1.0}) = 1$ | *5 | (pmem.@L) = 1 | | | | @ H + mem.bit | 2 | 2+S | Skip if (H+mem <sub>3-0</sub> .bit) = 1 | *1 | (@H+mem.bit) = | | | SKF | mem.bit | 2 | 2+S | Skip if (mem.bit) = 0 | *3 | (mem.bit) = 0 | | | | fmem.bit | 2 | 2+S | Skip if (fmem.bit) = 0 | *4 | (fmem.bit) = 0 | | | | pmem.@L | 2 | 2+S | Skip if $(pmem_{7\cdot2} + L_{3\cdot2}.bit (L_{1\cdot0}) = 0$ | *5 | (pmem.@L) = 0 | | | | @ H + mem.bit | 2 | 2+S | Skip if (H + mem <sub>3-0</sub> .bit) = 0 | *1 | (@H+mem.bit) = | | | SKTCLR | fmem.bit | 2 | 2+S | Skip if (fmem.bit) = 1 and clear | *4 | (fmem.bit) = 1 | | | | pmem.@L | 2 | 2+\$ | Skip if $(pmem_{7-2}+L_{3-2},bit (L_{1-0})) = 1$ and clear | *5 | (pmem.@L) = 1 | | | | @ H + mem.bit | 2 | 2+S | Skip if (H + mem <sub>3-0</sub> .bit) = 1 and clear | *1 | (@H+mem.bit)= | | Instruction | | | Number | Number of | | Addressing | | |-------------------------------|----------|----------------------|-------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------| | group | Mnemonic | Operand | of<br>bytes | machine<br>cycles | Operation | area | Skip condition | | | AND1 | CY, fmem.bit | 2 | 2 | CY - CY (fmem.bit) | *4 | - | | | | CY, pmem. @ L | 2 | 2 | CY — CY^<br>(pmem <sub>7-2</sub> +L <sub>3-2</sub> .bit (L <sub>1-0</sub> )) | *5 | | | Memory bit | | CY,<br>@ H + mem.bit | 2 | 2 | CY CYN (H + mem <sub>3-0</sub> .bit) | *1 | | | manipulation | OR1 | CY, fmem.bit | 2 | 2 | CY ← CY | *4 | | | instruction | | CY, pmem.@ L | 2 | 2 | CY — CY V<br>(pmem <sub>7-2</sub> + L <sub>3-2</sub> -bit (L <sub>1-0</sub> )) | *5 | | | , | | CY,<br>@ H + mem.bit | 2 | 2 | CY | *1 | | | | XOR1 | CY, fmem.bit | 2 | 2 | CY ← CY ← (fmem.bit) | *4 | | | | | CY, pmem.@ L | 2 | 2 | $\begin{array}{c} \text{CY} & _{i} \text{CY} \\ \text{(pmem}_{7\cdot2} + \text{ L}_{3\cdot2}.\text{bit } (\text{L}_{1\cdot0})) \end{array}$ | *5 | | | | | CY,@H+mem.bit | 2 | 2 | CY | *1 | - | | Branch | BR | addr | - | - | PC <sub>190</sub> → addr<br>(Select appropriate instruction<br>from among BR laddr, BRCB<br>lcaddr, and BR \$addr<br>according to the assembler<br>being used.) | *6 | | | instructions | | !addr | 3 | 3 | PC <sub>13-0</sub> ← addr | *6 | | | | | \$addr | 1 | 2 | PC <sub>13-0</sub> addr | *7 | | | | BRCB | !caddr | 2 | 2 | PC <sub>13-0</sub> PC <sub>13, 12</sub> + caddr <sub>11-0</sub> | *8 | | | | CALL | !addr | | | (SP -4) (SP - 1)<br>(SP -2) — PC <sub>11.0</sub><br>(SP -3) — (MBE, 0, PC <sub>13.1</sub> )<br>PC <sub>13.0</sub> — addr, SP — SP - 4 | | | | | CALLF | !faddr | 3 | 3 | (SP -4) (SP - 1) | *6 | | | | | | 2 | 2 | (SP -2) — PC <sub>11-0</sub><br>(SP -3) — (MBE, 0, PC <sub>13,12</sub> )<br>PC <sub>13-0</sub> — 0, faddr,<br>SP — SP - 4 | *9 | | | Subroutine | RET | | . 1 | 3 | (MBE, PC <sub>13,12</sub> ) - (SP +1)<br>PC <sub>11,0</sub> - (SP)(SP + 3)(SP + 2)<br>SP - SP + 4 | | | | stack control<br>instructions | RETS | | 1 | 3+S | (MBE, PC $_{13,12}$ ) — (SP +1)<br>PC $_{11,0}$ — (SP) (SP+3) (SP + 2)<br>SP — SP+4, then skip<br>unconditionally | | Unconditional | | | RETI | | 1 | 3 | PC <sub>13, 12</sub> (SP + 1)<br>PC <sub>11,0</sub> (SP) (SP+3) (SP+2)<br>PSW (SP + 4) (SP + 5),<br>SP SP + 6 | | / . | | | PUSH | rp | 1 | 1 | (SP -1) (SP - 2)— rp,<br>SP— SP - 2 | | | | | 33 | BS | 2 | 2 | (SP -1) MBS,<br>(SP -2) 0, SP SP - 2 | | | # STANDARD INSTRUCTION SET | | | · | | | | | | |---------------------------------|------------------|------------------------|-----------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------| | Instruction<br>group | Mnemonic | Operand | Number<br>of<br>bytes | Number of<br>machine<br>cycles | Operation | Addressing area | Skip condition | | Subroutine | POP | rp | 1 | 1 | rp— (SP + 1) (SP),<br>SP— SP + 2 | | · | | stack control instructions | | BS | 2 | 2 | MBS→ (SP+1),<br>SP→ SP + 2 | | | | | | | 2 | 2 | IME - 1 | | | | Interrupt<br>control | EI | IEXXX | 2 | 2 | IEXXX <del> </del> 1 | | | | instructions | DI | | 2 | 2 | IME ■ 0 | | | | | 51 | IEXXX | 2 | 2 | IEXXX → 0 | | | | | (Note 1) | A, PORT <sub>n</sub> | 2 | 2 | A → PORT <sub>n</sub> (n = port number) | | | | Input<br>output<br>instructions | IN | XA, PORT <sub>n</sub> | 2 | 2 | XA PORT <sub>n+1</sub> ,PORT <sub>n</sub><br>(n = port number) | | | | mistractions | (Note 1) | PORT <sub>n</sub> , A | 2 | 2 | PORT A (n = port number) | | | | | OUT | PORT <sub>n</sub> , XA | 2 | 2 | PORT <sub>n+1</sub> ,PORT <sub>n</sub> → XA<br>(n = port number) | | | | | HALT | | 2 | 2 | Set HALT Mode (PCC.2 - 1) | | | | CPU control instruction | STOP | | 2 | 2 | Set STOP Mode (PCC.3 | | | | | NOP | | 1 | 1 | No Operation | | | | | SEL | MB <sub>n</sub> | 2 | 2 | MBS <sub>n</sub> - n (n = 0, 1, 15) | | | | : | | · | | | • For TBR instruction PC <sub>13.0</sub> — (taddr) <sub>s.0</sub> + (taddr+1) | | | | Special<br>instructions | (Note 2)<br>GETI | taddr | 1 | 3 | • For TCALL instruction (SP -4) (SP -1) (SP -2) — PC <sub>(1,0</sub> (SP -3) — (MBE, 0, 0, PC <sub>(3,-12)</sub> PC <sub>(3,0</sub> — (taddr) <sub>8,0</sub> + (taddr+1) SP — SP-4 | *10 | | | | | | | | For any other instruction than<br>TBR or TCALL (taddr)<br>(taddr+1) instruction<br>execution | | Dependent on the referenced instruction | Note 1: To execute the IN or OUT instruction, preset MBE = 0 or (MBE = 1 and MBS = 15). The number of I/O ports allowing 8 bit data transfer, differs among the device types. Therfore, please check carefully the I/O pin manipulation instruction list for each device type which is available in the chapter about the on chip peripherals. Note 2: The TBR and TCALL instructions are assembler pseudo-instructions for GETI instruction table definition. # 3. Operation Codes of Each Instructions # (1) Explaination of operation code symbols | $R_2$ | R, | $R_{o}$ | reg | | | |-------|-------|---------|-------------|------|------| | 0000 | 0 0 1 | 0 1 0 1 | A<br>X<br>L | reg | 1 | | 1 | Ö | 0 | H | | reg1 | | 1 | 1 | 0 | D | | | | 1 | 1 | 1 | В | 1. 1 | 1 | | Q <sub>2</sub> | Q, | $Q_0$ | addressing | |----------------|----|-------|------------| | 0 | 0 | 1 | @HL | | 1 | 0 | 0 | @DE | | 1 | 0 | 1 | @DL | | P <sub>2</sub> | P <sub>1</sub> | reg-pair | |----------------|----------------|----------| | 0 | 0 | XA | | 0 | 1 | HL | | 1 | 0 | DE | | 1 | 1 | BC | | | | Ŧ | |------------|-----------------|----| | <b>A</b> _ | <b>Å</b><br>rp1 | rp | | p2<br>▼ | 1 | • | | IExxx | N <sub>o</sub> | N <sub>1</sub> | N <sub>2</sub> | N <sub>5</sub> | |--------------------|----------------|----------------|----------------|----------------| | IEBT | 0 | 0 | 0 | 0 | | IEW | 0 | 1 | 0 | 0 | | IET0 | 0 | 0 | 1 | 0 | | IECSI | 1 | 0 | 1 | 0 | | IE0 | 0 | 1 | 1 | 0 | | IE4 | 0 | 0 | 0 | 1 | | IEKS | 1 | 1 | 0 | 1 | | IE1 | 0 | 1 | 1 | 1 | | IE0<br>IE4<br>IEKS | 0 0 1 | 1 | 0 | 0 | In : Immediate data for n4, n8 Dn: Immediate data for mem Bn : Immediate data for bit Nn: Immediate data for n or IExxx Tn: Immediate data for taddr x 1/2 An: Immediate data for (relative address distance to branch destination address (2-16)) -1 Sn: Immediate data for one's complement of (relative address distance to branch destination address (15-1)) (2) Bit manipulation addressing operation codes under the operand cloumn denotes that the following three addressing modes are available: • fmem.bit • pmem.@L • @H+mem.bit The second byte \*2 of the operation code corresponding to each addressing mode shown above is as listed below: | *1 | Second byte of operation code | Bits that can be accessed | |------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------| | fmem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> F <sub>3</sub> F <sub>2</sub> F <sub>1</sub> F <sub>0</sub> FB0H-FBFH b | its that can be manipulated | | intent.bit | 1 1 B <sub>1</sub> B <sub>0</sub> F <sub>3</sub> F <sub>2</sub> F <sub>1</sub> F <sub>0</sub> FF0H-FFFH bi | its that can be manipulated | | pmem.@L | 0 1 0 0 G <sub>3</sub> G <sub>2</sub> G <sub>1</sub> G <sub>0</sub> FC0H-FFFH b | its that can be manipulated | | @H+mem.bit | 0 0 B <sub>1</sub> B <sub>0</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> Bits that can b | e manipulated in an accessible memory bank | Bn: Immediate data for bit Fn: Immediate data for fmem (low-order four bits of address are indicated) Gn: Immediate data for pmem (bits 5-2 of address are indicated) Dn: Immediate data for mem (low-order four bits of address are indicated) | Instruction Mnemonic | | Operand | Operation code | | | | |----------------------|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | group | | | $B_1$ $B_2$ $B_3$ | | | | | | - | A, #n4 | 0 1 1 1 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | | | | | | reg1, #n4 | 1 0 0 1 1 0 1 0 I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub> 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | | | | rp, #n8 | 1 0 0 0 1 P <sub>2</sub> P <sub>1</sub> 1 I <sub>7</sub> I <sub>6</sub> I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub> | | | | | | | A, @rpa | 1 1 1 0 0 Q <sub>2</sub> Q <sub>1</sub> Q <sub>0</sub> | | | | | | | XA, @HL | 1 0 1 0 1 0 1 0 0 0 0 1 1 0 0 0 | | | | | | | @HL, A | 1 1 1 0 1 0 0 0 | | | | | | | @HL, XA | 1 0 1 0 1 0 1 0 0 0 0 1 0 0 0 0 | | | | | | MOV | A, mem | 1 0 1 0 0 0 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | XA, mem | 1 0 1 0 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> 0 | | | | | | | mem, A | 1 0 0 1 0 0 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | Transfer | | mem, XA | 1 0 0 1 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> 0 | | | | | instructions | | A, reg1 | 1 0 0 1 1 0 0 1 0 1 1 1 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | | | | XA, rp' | 1 0 1 0 1 0 1 0 0 1 0 1 1 P <sub>2</sub> P <sub>1</sub> 0 | | | | | | | reg1, A | 1 0 0 1 1 0 0 1 0 1 1 1 0 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | | | | rp'1, XA | 1 0 1 0 1 0 1 0 0 1 0 1 0 P <sub>2</sub> P <sub>1</sub> 0 | | | | | | | A, @rpa | 1 1 1 0 1 Q <sub>2</sub> Q <sub>1</sub> Q <sub>0</sub> | | | | | | | XA, @HL | 1 0 1 0 1 0 1 0 0 0 0 1 0 0 0 1 | | | | | | | A, mem | 1 0 1 1 0 0 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | XCH | XA, mem | 1 0 1 1 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> 0 | | | | | | | A, reg1 | 1 1 0 1 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | | | | XA, rp | 1 0 1 0 1 0 1 0 0 1 0 0 0 P <sub>2</sub> P <sub>1</sub> 0 | | | | | | | | 1 1 0 1 0 1 0 0 | | | | | | MOVT | | 1 1 0 1 0 0 0 0 | | | | | Instruction | | | Operation code | | | |----------------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--| | group | Mnemonic | Operand | B <sub>1</sub> B <sub>2</sub> | В <sub>3</sub> | | | Arithmetic | ADDS | A, #n4 | 0 1 1 0 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | | | and<br>logical | | A, @HL | 1 1 0 1 0 0 1 0 | | | | instruction | ADDC | A, @HL | 1 0 1 0 1 0 0 1 | | | | | SUBS | A, @HL | 1 0 1 0 1 0 0 0 | | | | | SUBC | A, @HL | 1 0 1 1 1 0 0 0 | | | | | AND | A, #n4 | 1 0 0 1 1 0 0 1 0 0 1 1 <sub>3</sub> <sub>2</sub> <sub>1</sub> <sub>0</sub> | | | | | | A,@HL | 1 0 0 1 0 0 0 0 | | | | | OR | A, #n4 | 1 0 0 1 1 0 0 1 0 1 0 0 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | | | | • | A,@HL | 1 0 1 0 0 0 0 0 | | | | | XOR | A, #n4 | 1 0 0 1 1 0 0 1 0 1 0 1 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | | | | | A,@HL | 1 0 1 1 0 0 0 0 | - ' | | | ACC | RORC | Α | 1 0 0 1 1 0 0 0 | | | | | NOT | Α | 1 0 0 1 1 0 0 1 0 1 0 1 1 1 1 1 | | | | Inc/dec | INCS | reg | 1 1 0 0 0 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | | | @HL | 1 0 0 1 1 0 0 1 0 0 0 0 0 1 0 | | | | | | mem | 1 0 0 0 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | DECS | reg | 1 1 0 0 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | Compare | SKE | reg, #n4 | 1 0 0 1 1 0 1 0 I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub> 0 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | | | @HL, #n4 | 1 0 0 1 1 0 0 1 0 1 1 0 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | | | | | A, @HL | 1 0 0 0 0 0 0 0 | | | | | | A, reg | 1 0 0 1 1 0 0 1 0 0 0 0 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> | | | | Carry | SET1 | CY | 1 1 1 0 0 1 1 1 | | | | | CLR1 | CY | 1 1 1 0 0 1 1 0 | | | | | SKT | CY | 1 1 0 1 0 1 1 1 | | | | | NOT1 | CY | 1 1 0 1 0 1 1 0 | | | | Memory bit | SET1 | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 0 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | instruction | | *1 | | | | | | CLR1 | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 0 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>9</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | *1 | 1 0 0 1 1 1 0 0 *2 | | | | | SKT | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | *1 | 1 0 1 1 1 1 1 1 *2 | | | | | SKF | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | *1 | 1 0 1 1 1 1 0 *2 | | | | | SKTCLR | *1 | 1 0 0 1 1 1 1 1 *2 | | | | | AND1 | CY, *1 | 1 0 1 0 1 1 0 0 *2 | | | | | OR1 | CY, *1 | 1 0 1 0 1 1 1 0 *2 | | | | | XOR1 | CY, *1 | 1 0 1 1 1 1 0 0 *2 | | | # STANDARD INSTRUCTION SET | Instruction | Mnemonic Operand | | Operation code | | | | |----------------|------------------|------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------|----------------|--| | group | IVIII CITICITIC | Operanu | B <sub>1</sub> | В <sub>2</sub> | B <sub>3</sub> | | | Branch | BR | !addr | 1 0 1 0 1 0 1 1 | | addr | | | | | (+16) - (+2) | 0 0 0 0 A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> | | | | | | | \$addr<br>(-1) - (-15) | 1 1 1 1 S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> | | | | | | BRCB | lcaddr | 0 1 0 1 | caddr | | | | Subroutine | CALL | !addr | 10101011 | 0 1 0 | — addr — — | | | stack | CALLF | !faddr | 0 1 0 0 0 | faddr | | | | | RET | | 1 1 1 0 1 1 1 0 | | | | | | RETS | | 1 1 1 0 0 0 0 0 | | | | | | RETI | | 1 1 1 0 1 1 1 1 | | | | | | PUSH | rp | 0 1 0 0 1 P <sub>2</sub> P <sub>1</sub> 1 | | | | | | | BS | 1 0 0 1 1 0 0 1 | 0 0 0 0 0 1 1 1 | | | | | POP | rp | 0 1 0 0 1 P <sub>2</sub> P <sub>1</sub> 1 | | | | | | | BS | 1 0 0 1 1 0 0 1 | 0 0 0 0 0 1 1 0 | | | | In/out | IN | A, PORTn | 1 0 1 0 0 0 1 1 | 1 1 1 1 N <sub>3</sub> N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | | XA, PORTn | 1 0 1 0 0 0 1 0 | 1 1 1 1 N <sub>3</sub> N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | OUT | PORTn, A | 1 0 0 1 0 0 1 1 | 1 1 1 1 N <sub>3</sub> N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | | PORTn, XA | 1 0 0 1 0 0 1 0 | 1 1 1 1 N <sub>3</sub> N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | Interrupt | El | | 10011101 | 1 0 1 1 0 0 1 0 | | | | | | IEXXX | 1 0 0 1 1 1 0 1 | 1 0 N <sub>5</sub> 1 1 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | DI | | 10011100 | 1 0 1 1 0 0 1 0 | | | | | | IEXXX | 1 0 0 1 1 1 0 0 | 1 0 N <sub>5</sub> 1 1 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | CPU<br>control | HALT | | 1 0 0 1 1 1 0 1 | 1 0 1 0 0 0 1 1 | | | | | STOP | | 1 0 0 1 1 1 0 1 | 1 0 1 1 0 0 1 1 | | | | | NOP | | 0 1 1 0 0 0 0 0 | | | | | Special | SEL | MBn | 1 0 0 1 1 0 0 1 | 0 0 0 1 N <sub>3</sub> N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | GETI | taddr | 0 0 T <sub>5</sub> T <sub>4</sub> T <sub>3</sub> T <sub>2</sub> T <sub>1</sub> T <sub>0</sub> | | | | ## 4. INSTRUCTION FUNCTIONS AND APPLICATIONS #### 4.1 Transfer instructions MOV A. #n4 Function: $A \longrightarrow n4$ $n4 = I_{3-0}$ : 0-FH This instruction transfers 4-bit immediate data n4 to the A register (4-bit accumulator). It has a string effect (group A). If the MOV A, #n4 or MOV XA, #n8 instruction is consecutively placed, the instruction that follows the executed instruction will be replaced with an NOP instruction. Application examples: (1) Sets 0BH into the accumulator: MOV A, #0BH (2) Selects data to be output to Port 3 from 0 to 2: A0: MOV A, #0 A1: MOV A, #1 A2: MOV A, #2 OUT PORT3. A MOV reg1, #n4 Function: Reg1 → n4 n4 = I<sub>3.0</sub>: 0-FH This instruction transfers 4-bit immediate data n4 to the reg1 register (X, H, L, D, E, B, C). MOV rp, #n8 Function: rp - #n8 $n8 = I_{7.0}$ : 00H-FFH This instruction transfers 8-bit immediate data n8 to the register pair rp (XA, HL, DE, BC). It has a string effect if the XA or HL is specified for rp. The string effect includes Group A (MOV A, #n4 and MOV XA, #n8 instruction). If instructions belonging to the same group are consecutively placed in a program, the string effect instruction that follows the executed instruction is replaced with an NOP instruction Application example: Sets 5FH into DE register pair. MOV DE, #5FH MOV A, @rpa Function: A→ (rpa) This instruction transfers the contents of the data memory location addressed by the register pair rpa (HL, DE, DL) to the A register. MOV XA, @HL Function: A → (HL), X → (HL+1) This instruction transfers the contents of the data memory addressed by register pair HL to the A register and those of the next memory location to the X register. If the L register value is an odd number, the least significant bit of the address information will be ignored. Application example: Transfers data in addresses 3EH and 3FH to the register pair XA. MOV HL, #3EH MOV XA, @HL MOV @HL, A Function: (HL) - A This instruction transfers the A register value to the data memory location addressed by the register pair HL. MOV @HL, XA This instruction transfers the A register value to the data memory location addressed by the register pair HL, and the X register value to the next data memory location. If the L register value is an odd number, the least significant bit of the address information will be ignored. MOV A, mem Function: A ← (mem) This instruction transfers the contents of the data memory location addressed by 8-bit immediate data mem to the A register. MOV XA, mem Function: $A \leftarrow (mem), X \leftarrow (mem+1) \quad mem = D_{7.0}: 00H-FEH$ This instruction transfers the contents of the data memory location addressed by 8-bit immediate data mem to the A register, and the contents of the next data memory location to the X register. The address specifiable with mem is an even address. $mem = D_{7,0}$ : 00H-FFH Application example: Transfers the data in location 40H and 41H to the register pair XA: MOV XA, 40H MOV mem, A Function: $(mem) \rightarrow A$ , $mem = D_{7,0} 00H-FFH$ This instruction transfers the A register value to the data memory location addressed by 8-bit immediate data mem. MOV mem, XA Function: $(mem) \rightarrow A$ , $(mem+1) \rightarrow X$ $mem = D_{7-0}$ : 00H-FEH This instruction transfers the A register value to the data memory location addressed by 8-bit immediate data mem and the X register value to the next data memory location. The address specifiable by mem is an even address. MOV A, reg1 Function: A → reg1 This instruction transfers the value of the register reg1 (X, H, L, D, E, B, C) to the A register. MOV XA, rp Function: XA-→ rp This instruction transfers the value of the register rp (XA, HL, DE, BC) to the register pair XA. MOV reg1, A Function: regl - A This instruction transfers the A register value to the register reg1 (X, H, L, D, E, B, C). MOV rp1, XA This instruction transfers the value of the register pair XA to another register pair, rp1 (HL, DE, BC). XCH A, @rpa Function: A (rpa) This instruction exchanges the A register value with the contents of the data memory location addressed by the register pair rpa (HL, DE, DL). Application example: Exchanges data in data memory locations 20 to 2FH with those in locations 30 to 3FH: SEL MBO MOV D, #2 MOV HL, #30H XCH A, @HL; A → (3x) XCH A, @DL; A → (2x) XCH A, @HL; A → (3x) INCS L BR LOOP XCH XA, @HL Function: A → (HL), X → (HL+1) LOOP: This instruction exchanges the A register value with the contents of the data memory location addressed by the register pair HL, and the X register value with the contents of the next data memory location. If the Lregister value is an odd number, the least significant bit of the address information will be ignored. XCH A, mem Function: $A \leftrightarrow (mem), X \leftrightarrow (mem+1)$ mem = $D_{7,0}$ : 00H-FFH $This instruction \, exchanges \, the \, A \, register \, value \, with \, the \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, of \, the \, data \, memory \, \, location \, addressed \, and \, contents \, and \, contents \, addressed \, and \, contents \, addressed \, and \, contents \, addressed \, and \, contents \, addressed ad$ by 8-bit immediate mem. XCH XA, mem $A \leftrightarrow (mem), X \leftrightarrow (mem+1)$ mem = $D_{7.0}$ : 00H-FEH This instruction exchanges the A register value with the contents of the data memory location addressed by 8-bit immediate data mem and the X register value with the contents of the next data memory location. The address specifiable with mem is an even address. XCH A, reg1 Function: A ← reg1 This instruction exchanges the A register value with the value of the register reg1 (X, H, L, D, E, B, C). XCH XA, rp Function: XA → rp This instruction exchanges the value of register pair XA with that of another register pair rp (XA, HL, DE, RC) #### 4.2 Table reference instructions MOVT XA, @PCDE Function: XA → ROM (PC<sub>13.8</sub>+DE) This instruction transfers the lower 4 bits of table data in the program memory location addressed by the higher 6 bits ( $PC_{13-8}$ ) of the program counter (PC) plus DE register pair value to the A register, and the higher 4 bits of the same table data to the X register. The higher 6 bits of the table address are determined by the program counter value at the time of the execution of this instruction. Necessary data must be programmed on the table area beforehand by using an assembler's pseudoinstruction (DB instruction). The program counter value is not affected by the execution of this instruction. This instruction is effective to continuously refer to table data. Note: The MOVT XA, @PCDE instruction normally references to the table data on the page where the instruction is located. If the instruction is located in address xxFFH, it references the table data on the next page. If, for example, the MOVT XA, @PCDE instruction is placed in location ① in the above figure, it transfers the table data (specified by the value of register pair DE, not on page 2 but on page 3) to register pair XA. Application example: Transfers the 8-byte data in program memory locations xxF8H to xxFFH to data memory locations 40 to 4FH. SUB: SEL M<sub>B</sub>0 MOV HL, #40H; HL - 40H MOV DE, #0F8H; DE - F8H LOOP: MOVT XA, @PCDE; XA - table data MOV @HL. XA: (HL) -XA INCS HL - HL+2 L: **INCS** L **INCS** E: E - E+1 LOOP BR RET ORG xxF8H xxH, xxH, ...; DB table data ## MOVT XA, @PCXA Function: This instruction transfers the lower 4 bits of the table data in the program memory location addressed by the upper 6 bits (PC<sub>13-8</sub>) of the program counter (PC) plus the value of the register pair XA to the A register, and the higher 4 bits of the same table data to the X register. The higher 6 bits of the table address are determined by the PC value at the time of the execution of this instruction. Necessary data must be programmed in the table area beforehand by using an assembler's directive (DB instruction). The program counter value is not affected by the execution of this instruction. Note: If this instruction is placed in location xxFFH, the table data on the next program memory page will be transferred (similar to the MOVT XA, @PCDE instruction). #### 4.3 Operational instructions ADDS A, #n4 Function: A - A + n4; Skip if carry. $n4 = I_{3.0}$ : 0H-FH This instruction adds 4-bit immediate data n4 to the A register value (binary). If a carry is produced, the instruction following this instruction is skipped. The carry flag is not affected. When this instruction is combined with the ADDC A, @HL or SUBC A, @HL instruction, it functions as a notation change instruction (see 1.4). ADDS A, @HL Function: A - A + (HL); Skip if carry. This instruction adds the contents of the data memory location addressed by the register pair HL to the A register value (binary). If a carry is produced, the instruction following this instruction is skipped. The carry flag is not affected. ADDC A, @HL Function: A, CY - A + (HL) + CY This instruction adds the contents (including the carry flag) of the data memory location addressed by the register pair HL to the A register value in binary. If a carry is produced, the carry flag is set; if not, the flag is reset. If a carry is produced when this instruction is followed by the ADDS A, #n4 instruction, the ADDS A, #n4 instruction will be skipped. If no carry is produced, the ADDS A, #n4 instruction will be executed with its skip function inhibited. Therefore, these instruction are usable for notation change operation when combined (see 1.4). SUBS A, @HL Function: $A \rightarrow A - (HL)$ ; Skip if borrow. This instruction subtracts the contents of the data memory location addressed by the register pair HL from the A register value in binary and sets the result into the A register. If a borrow is produced, the instruction following this instruction is skipped. This instruction does not affect the carry flag. SUBC A, @HL Function: A, CY - A - (HL) - CY This instruction subtracts the contents of the data memory location addressed by register pair HL from the A register value including carry flag in binary and sets the result into the A register. If a borrow is produced, the carry flag is set; if not, the flag is reset. If no borrow is produced when this instruction is followed by an ADDS A, #n4 instruction, the ADDS A, #n4 instruction will be skipped. If a borrow is produced, the ADDS A, #n4 instruction is executed with its skip function inhibited. Therefore, these instructions can be used for notation change operation (see 1.4). AND A, #n4 Function: $A \rightarrow A \wedge n4 \quad n4 = I_{3,0}$ : 0H-FH This instruction ANDs the A register value with 4-bit immediate data n4 and sets the result into the A register. Application example: Sets the higher 2 bits of the accumulator to 0: AND A, #0011B AND A, @HL Function: A→ A ∧ (HL) This instruction ANDs the A register value with the contents of the data memory location addressed by the register pair HL and sets the result into the A register. OR A. #n4 Function: $$A \leftarrow A \lor n4 \quad n4 = I_{3-0}$$ : 0H-FH This instruction ORs the A register value with 4-bit immediate data n4 and sets the result into the A register. Application example: Sets the lower 3 bits of the accumulator to 1: OR A. #0111B OR A, @HL Function: This instruction ORs the A register value with the contents of the data memory location addressed by the register pair HL and sets the result into the A register. XOR A. #n4 Function: This instruction XORs the A register value with 4-bit immediate data n4 and sets the result into the A register. Application example: Inverts the MSB of the A register: XOR A, #1000B XOR A, @HL Function: This instruction XORs the A register value with the contents of the data memory location addressed by the register pair HL and sets the result into the A register. #### 4.4 Accumulator manipulation instructions #### **RORC A** Function: $$CY - A_0$$ , $A_{n-1} - An$ , $A_3 - CY$ $(n = 1-3)$ This instruction rotates the contents of the A register (4-bit accumulator) right by 1 bit through the carry flag. NOT A Function: $$A \rightarrow \overline{A}$$ This instruction complements the A register (4-bit accumulator) (invert each bit). #### 4.5 Increment/decrement instructions **INCS** rea Function: This instruction increments the value of the register reg (X, A, H, L, D, E, B, C) by one. If reg = 0 when incremented, the instruction following this instruction will be skipped. ## STANDARD INSTRUCTION SET INCS @HL Function: $(HL) \leftarrow (HL + 1; Skip if (HL) = 0)$ This instruction increments the contents of the data memory location addressed by the register pair HL. If the contents of the data memory location become zero when incremented, the instruction following this instruction will be skipped. **INCS** mem Function: $(mem) \rightarrow (mem) + 1$ ; Skip if (mem) = 0, $(mem) = D_{7.0}$ : 00H-FFH This instruction increments the contents of the data memory location addressed by the 8-bit immediate data mem. If the contents of the data memory location become zero when incremented, the instruction following this instruction will be skipped. **DECS** reg Function: reg - 1; Skip if reg = FH. This instruction decrements the value of the register reg (X, A, H, L, D, E, B, C). If reg = FH when decremented, the instruction following this instruction will be skipped. 4.6 Compare instructions SKE reg, #n4 Function: Skip if reg = n4 $n4 = I_{3-0}$ : 0H-FH This instruction skips the instruction following it if the value of the register reg (X, A, H, L, D, E, B, C) is equal to the 4-bit immediate data n4. SKE @HL, #n4 Function: Skip if (HL) = n4 $n4 = I_{3-0}$ : 0H-FH This instruction skips the instruction following it if the value of the data memory location addressed by the register pair HL is equal to the 4-bit immediate data n4. SKE A, @HL Function: Skip if A = (HL) This instruction skips the instruction following it if the A register value is equal to the value of the data memory location addressed by the register pair HL. SKE A, reg Function: Skip if A = rea This instruction skips the instruction following it if the A register value is equal to the value of the register reg (X, A, H, L, D, E, B, C). 4.7 Carry flag manipulation instructions SET1 CY Function: CY 1 This instruction sets the carry flag. CLR1 CY This instruction clears the carry flag. SKT CY Function: Skip if CY -1 This instruction skips the instruction following it if the carry flag is set to 1. NOT1 CY Function: This instruction reverses the carry flag status, from 0 to 1 or vice versa. ## 4.8 Memory bit manipulation instructions SET1 mem. bit Function: (mem. bit) $$\stackrel{*}{-}$$ 1 mem = D<sub>7-0</sub>: 00H-FFH, bit = B<sub>1-0</sub>: 0-3 This instruction sets the data memory bit specified by the 2-bit immediate data "bit" at the location addressed by the 8-bit immediate data "mem". SET1 fmem. bit SET1 pmem, @L SET1 @H + mem. bit Function: (Bit specified by operand) - 1 These instructions set the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit). CLR1 mem. bit Function: (mem. bit) $\rightarrow$ 0 mem 0 D<sub>7.0</sub>: 00H-FFH, bit = B<sub>1.0</sub>: 0-3 This instruction clears the data memory bit specified by the 2-bit immediate data "bit" at the location specified by the 8-bit immediate data "mem". CLR1 fmem. bit CLR1 pmem. @L CLR1 @H + mem. bit Function: These instruction s clear the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit). SKT mem. bit Function: Skip if (mem, bit) = 1 mem = $D_{7-0}$ : 00H-FFH, bit = $B_{1-0}$ : 0-3 This instruction skips the instruction following it if the data memory bit specified by the 2-bit immediate data "bit" at the location specified by the 8-bit immediate data "mem" is equal to 1. SKT fmem. bit SKT pmem. @L SKT @H + mem. bit Function: Skip if (bit specified by operand) = 1 These instructions skip the instruction following it if the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit) is equal to 1. SKF mem. bit Function: Skip if (mem. bit) = 0 mem = $D_{7.0}$ : 00H-FFH, bit = $B_{1.0}$ : 0-3 This instruction skips the instruction following it if the data memory bit specified by the 2-bit immediate data "bit" at the location specified by the 8-bit immediate data "mem" is equal to 0. ## STANDARD INSTRUCTION SET SKF fmem. bit SKF pmem. @L SKF @H + mem. bit Function: Skip if (bit specified by operand) = 0 These instructions skip the instruction following it if the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit) is equal to 0. SKTCLR fmem. bit SKTCLR pmem. @L SKTCLR @H + mem. bit Function: Skip if (bit specified by operand) = 1, then clear it These instructions skip the instruction following it if the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit) is equal to 1, then clear the bit to 0. AND1 CY, fmem. bit AND1 CY, pmem. @L AND1 CY, @H + mem. bit Function: CY CY (bit specified by operand) These instructions AND the carry flag value with the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit) and set the result into the carry flag. OR1 CY, fmem. bit OR1 CY, pmem. @L OR1 CY, @H + mem. bit Function: These instructions OR the carry flag value with the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit) and set the result into the carry flag. XOR1 CY, fmem. bit XOR1 CY, pmem. @L XOR1 CY, @H + mem. bit Function: These instructions XOR the carry flag value with the data memory bit specified by the bit manipulation addressing (fmem. bit, pmem. @L, @H + mem. bit) and set the result into the carry flag. 4.9 Branch instruction BR addr Function: PC<sub>13-0</sub> addr = 0000H-3F7FH (depends upon available ROM of the selected device) This instruction causes control to branch to the address specified by the 14-bit immediate data, addr. It is an assembler's pseudoinstruction and is automatically replaced with an appropriate instruction out of the BR laddr, BRCB lcaddr and BR \$addr instruction when assembling. BR !addr Function: PC<sub>13-0</sub> addr addr = 0000H-3F7FH (depends upon available ROM of the selected device) This instruction transfers the 14-bit immediate data addr to the program counter (PC) to make branch to the address specified by the PC value. Branching is possible to any location on the program memory space. BR \$addr Function: PC addr = (PC-15) to (PC-1), (PC+2) to (PC+16) This instruction causes control to branch to an address which is -15 to +16 with respect to the current address. It is not affected by page or block boundaries. #### BRCB !caddr Function: This instruction causes control to branch to the address which is obtained by replacing the lower address which is obtained by replacing the lower 12 bits ( $PC_{11.0}$ ) of the program counter with the 12-bit immediate data caddr ( $A_{11.0}$ ). PC<sub>13, 12</sub> can not be modified and this branch results in an in-block branch. Note: The BRCB lcaddr instruction normally causes branching within the block where it is located. If the first byte of the instruction is located in address 0FFEH or 0FFFH, it causes branching to block 1, not to block 0. If the BRCB laddr instruction is located in (1) or (2) of the above figure, it causes branching to block 1, not to block 0. #### TBR addr Function: This is an assembler directive for a table definition of the GETI instruction. For details, see $\mu$ COM-75X Family Relocatable Assembler Package Operation Manual which is part of the $\mu$ COM-75X Family 4Bit CMOS Microcomputer Development Tool book. ### 4.10 Subroutine stack control instruction #### CALL !addr Function: $$\begin{array}{l} (\text{SP-1}) \longrightarrow \text{PC}_{7,4}, (\text{SP-2}) \longrightarrow \text{PC}_{3,0}, (\text{PC-3}) \longrightarrow \text{MBE}, 0, \text{PC}_{13,12}, (\text{SP-4}) \longrightarrow \text{PC}_{11,8}, \\ \text{PC}_{13} \longrightarrow \text{addr}, \text{SP} \longrightarrow \text{SP-4}, \text{addr} = 0000\text{H-}3\text{F7FH} \text{ (depends on the selected device type.} \end{array}$$ This instruction saves the values of the program counter (PC<sub>13-0</sub>: return address) and MBE to the data memory locations (stack) addressed by the stack pointer (SP), decrements the SP, and causes branch to the address specified by the 14-bit immediate data addr. Branching is possible to any location on the program memory space. #### CALLF !faddr Function: $$\begin{array}{lll} (\text{SP-1}) & & \text{PC}_{7.4}, (\text{SP-2}) & & \text{PC}_{3.0}, (\text{PC-3}) & & \text{MBE, 0, PC}_{13, 12}, (\text{SP-4}) & & \text{PC}_{11.8}, \\ \text{SP---} & \text{SP-4}, \text{PC} & & 000, \text{A}_{10.0}, \text{faddr} & = \text{A}_{10.0}; 000\text{H-7FFH} \\ \end{array}$$ This instruction saves the values of the program counter (PC return address) and MBE to the data memory locations (stack) addressed by the stack pointer (SP), decrements the SP, and causes branching to the address specified by the 11-bit immediate data faddr. The program memory area which can be called is limited to addresses 0000 through 07FFH (0-2047). #### TCALL addr Function: This is an assembler directive for a table defination of the GETI instruction. It is used for replacing the 3-byte CALL instruction with a GETI instruction. Write a call address of the 3-byte CALL instruction for an addr of the TCALL. For details, see $\mu$ COM-75X Family 4-Bit CMOS Microcomputer Development Tool book. ## STANDARD INSTRUCTION SET RET Function: $$PC_{11.8} - (SP)$$ , MBE, $PC_{13, 12} - (SP+1)$ , $PC_{3.0} - (SP+2)$ $PC_{7.4} - (SP+3)$ , $SP - SP+4$ This instruction restores the contents of the data memory (stack) locations addressed by the stack pointer (SP) into the program counter (PC) and memory bank enable flag (MBE), then increments the Note: The program status word (PSW) is not restored with the exception of the MBE. RETS Function: This instruction restores the contents of the data memory (stack) locations addressed by the stack pointer (SP) into the program counter (PC) and memory bank enable flag (MBE), increments the SP value, and makes an unconditional skip. Note: The program status word (PSW) is not restored with the exception of the MBE. RETI Function: $$\begin{array}{lll} {\sf PC}_{1.18} \leftarrow ({\sf SP}), \, {\sf PC}_{13,12} \leftarrow ({\sf SP}+1), \, {\sf PC}_{3.0} \leftarrow ({\sf SP}+2) \, {\sf PC}_{7.4} \leftarrow ({\sf SP}+3), \, {\sf PSW}_{\rm L} \leftarrow ({\sf SP}+4), \, {\sf PSW}_{\rm L} \leftarrow ({\sf SP}+5), \, {\sf SP} \leftarrow {\sf SP}+6 \end{array}$$ This instruction restores the contents of the data memory locations (stack) addressed by the stack pointer (SP) into the program counter (PC) and program status word (PSW), then increments the SP value. It is used to return from an interrupt service routine. PUSH rp Function: $$(SP-1) - rp_H$$ , $(SP-2) - rp_I$ , $SP - SP-2$ This instruction saves the contents of the register pair rp (XA, HL, DE, BC) to the data memory locations (stack) addressed by the stack pointer (SP), then decrements the SP value. The higher 4 bits (rp, X, H, D, B) of the register pair are saved to the stack addressed by (SP-1), while the lower 4 bits (rp.: A, L, E, C) of it is saved to the stack addressed by (SP-2). **PUSH BS** Function: This instruction saves the contents of the memory bank select register (MBS) to the data memory locations (stack) addressed by the stack pointer (SP), then decrements then SP. POP rp Function: This instruction restores the contents of the data memory locations (stack) address by the stack pointer (SP) into the register pair rp (XA, HL, DE, BC) then increments the SP. The contents of the (SP) are restored into the lower 4 bits of the register pair (rp, : A, L, E, C) while those of the (SP+1) are restored into the higher 4 bits of the register pair (rp, : X, H, D, B). POP BS Function: This instruction restores the contents of the data memory locations (stack) address by the stack pointer (SP) to the memory bank select register (MBS), then increments the SP. 4.11 Interrupt control instructions FI Function: This instruction sets the interrupt enable master flag to 1 to enable interrupt. Whether a specific interrupt is acknowledged or not is determined by individual interrupt enable flag. El IExxx Function: $IExxx - 1 xxx = N_{5-0}$ This instruction sets the interrupt flag (IExxx) to 1 to enable the corresponding interrupt request. DI Function: IME - 0 This instruction resets the interrupt enable master flag to 0 to disable all interrupts regardless of the status of their individual interrupt enable flags. DI IExxx Function: $IExxx - 0 xxx = N_{5.0}$ This instruction resets the interrupt flag (IExxx) to 0 to disable the corresponding interrupt request. #### 4.12 Input/output instructions #### IN A. PORTn Function: A PORTn This instruction transfers the contents of the port specified by PORTn to the A register. Note: When executing this instruction, the MBE = 0 or (MBE = 1 and MBS = 15) must be set. When the I/O mode specified, the output latch data (output mode) or pin data (input mode) is loaded to the #### IN XA, PORTn Function: A register. This instruction transfers the contents of the port specified by PORTn and the contents of the next port to the X register. Note: When executing this instruction, the MBE = 0 or (MBE = 1 and MBS = 15) must be set beforehand. Only the values for "n" are allowed where input port instruction is enabled by the list of I/O pin manipulation instructions which are part of the chapter regarding on chip peripherals. Note that "n" differs among the device types! When the I/O mode is specified, the output latch data (output mode or pin data (input mode) is loaded to the XA registers. ## **OUT PORTn, A** Function: This instruction transfers the A register value to the output latch in the port specified by PORTn. Note: When executing this instruction, the MBE = 0 or (MBE = 1 and MBS = 15) must be set beforehand. Only the values for "n" are allowed where output port instruction is enabled by the list of I/O pin manipulation instructions which are part of the chapter regarding on chip peripherals. Note that "n" differs among the device types! When the I/O mode is specified, the output latch data (output mode or pin data (input mode) is loaded to the A register. ## **OUT PORTn, XA** Function: This instruction transfers the A register value to the output latch in the port specified by PORTn, and the X register value to the output latch on the next port. Note: When executing this instruction, MBE = 0 or (MBE = 1 and MBS = 15) must be set beforehand. It depends on the physical availability of the port on the selected device type if this instruction is executable. Therefore check the chapter regarding the on chip peripherals first. Note that "n" differs among the device types! ## STANDARD INSTRUCTION SET #### 4.13 CPU control instructions HALT Function: PCC.2 -1 This instruction selects the HALT mode (sets bit 2 of the processor clock control register). Note: The HALT instruction must be followed by a NOP instruction. STOP Function: PCC. 3 -1 This instruction sets the STOP mode (sets bit 3 of the processor clock control register). Note: The STOP instruction must be followed by a NOP instruction. NOP Function: Causes no operation to consume an idle machine cycle. #### 4.14 Special instructions SEL MBn Function: MBS-n n = N<sub>3-0</sub>: 0, 1, 15 This instruction transfers the 4-bit immediate data n to memory bank select register (MBS). Number 0, 1, or 15 is allowed for n presently. **GETI** taddr Function: taddr = T<sub>5.0</sub>, 0: 20H-7FH · For TBR instruction $PC_{13-0} - (taddr)_{5-0} + (taddr + 1)$ • For TCALL instruction (SP-4) (SP-1) (SP-2) — PC<sub>11-0</sub> (SP-3) — (MBE, 0, PC13, 12) PC<sub>13-0</sub> - (taddr)<sub>5-0</sub> + (taddr + 1) SP - SP-4 . For other than TBR. TCALL instruction Executes the instruction whose instruction code is (taddr) (taddr + 1). This instruction references the 2-byte data located in the program memory locations specified by taddr and (taddr + 1), then executes it as an instruction. The reference table area is 0020 to 007FH, in which data must be written beforehand. For 1- or 2-byte instruction, mnemonics should be written with a pseudoinstruction (TCALL, TBR). Only even-number addresses may be specified for taddr. Note: For 2-byte instructions, only 2-machine cycle instructions can be set on the reference table (Except BRCB and CALLF instructions). When setting two 1-byte instructions on the table, their combinations are limited to those listed in the following table: | 1st byte instruction | 2nd byte instruction | |----------------------|----------------------| | MOV A, @HL | ( INCS L<br>DECS L | | MOV @HL, A | DECS L | | , | (INCS H<br>DECS H | | XCH A, @HL | `DECS H | | | | | MOV A, @DE | (INCS E | | XCH A, @DE | `DECS E | | 7,01171, @52 | (INCS D<br>DECS D | | | DECS D | | | | | MOV A, @DL | ( INCS L<br>DECS L | | XCH A, @DL | `DECS L | | AOITA, WDL | , INCS D | | | DECS D | Since the PC is not incremented during GETI instruction execution, execution resumes in the address next to the GETI instruction address when the execution of the reference instruction is completed. If the instruction precending the GETI instruction has skip feature, the GETI instruction is skipped in the same way as other 1-byte instructions. If the instruction referenced with the GETI instruction has a skip function, the instruction that follows the GETI instruction will be skipped. If an instruction having the string effect is referenced with the GETI instruction, the following will occur: - If the GETI instruction is preceded by an instruction belonging to the same string effect group, the execution of the GETI instruction cancels the effect, and the instruction which was referenced is not skipped. - If the GETI instruction is followed by an instruction belonging to the same string effect group, the string effect of the instruction which was referenced remains valid, and the instruction following it will be skipped. Application example: | Replace | MOV HL<br>MOV XA<br>CALL SU<br>BR SUB | , #FFH<br>JB1 | with the GETI instruction | |---------------------------------------------|---------------------------------------|---------------------------------------------------|---------------------------| | CODE0<br>HL00:<br>XAFF:<br>CSUB1:<br>BSUB2: | CSEG<br>MOV<br>MOV<br>TCALL<br>TBR | IENT<br>HL, #00H<br>XA, #FFH<br>SUB1<br>SUB2<br>: | | | | GETI | HL00<br>: | ; MOV HL, #00H | | | GETI | BSUB2 | ; BR SUB2 | | | GETI | CSUB1 | ; CALL SUB1 | | | GETI | XAFF | ;MOV XA, #0FFH | ## CHAPTER 6 µPD75402A LOW END 4 BIT MICROCOMPUTER #### 1. OVERVIEW The $\mu$ PD75402A, $\mu$ PD75P402 is a CMOS 4-bit single chip computer adopting the $\mu$ COM-75X architecture. The microcomputer which enables high speed processing and has internal NEC standard serial bus interface is suitable for a slave microcomputer in the multiprocessor system configuration in which the $\mu$ COM-75X or $\mu$ COM-78K series is used as the host microcomputer. The host microcomputer load can be relieved by using the $\mu$ PD75402A, $\mu$ PD75P402 as a slave microcomputer for distributed processing. It is applicable to slave processing such as key input control and LED display countrol or remote control transfer control of the following: - Facsimile - PPC - Printer - · Electronic cash register - · Video tape recorder - · Remote control commander The $\mu$ PD75P402 is QTOP<sup>TM</sup> microcomputer provided by replacing $\mu$ PD75402A internal mask ROM with one time PROM. It is compatible with the $\mu$ PD75402A except for program memory or mask option. Pin connection at write is the same as that of standard EPROM $\mu$ PD27C256A and the $\mu$ PD75P402 has the same write characteristic as the $\mu$ PD27C256A. Thus, the $\mu$ PD75P402 can be written directly by using a general purpose PROM writer. It is suitable for test production at system development or few-of-a-kind parts production. | Product name | Program memory | Data memory | |--------------|--------------------------|--------------| | μPD75402A | 1920 x 8 (mask ROM) | 64 x 4 (RAM) | | μPD75P402 | 1920 x 8 (one time PROM) | 64 x 4 (RAM) | Remarks: This manual explains the $\mu$ PD75402A as representative product unless otherwise noted. If you use the manual for the $\mu$ PD75P402, replace the $\mu$ PD75402A with the $\mu$ PD75P402 in reading. #### QTOP is a trademark of NEC #### 1.1 Function Outline | Item Number of basic instructions Minimum instruction execution time | | Description 37 • 0,95μs, 1.91 or 15.3μs (at 4.19 MHz) Either can be selected. | | | | | | |------------------------------------------------------------------------|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--------------------------------|-------------|-------------------------------------------------------------------|--| | | | | | Internal memory Program memory | | 1920 x 8 bits (mask ROM (μPD75402A) or one time PROM (μPD75P402)) | | | | | | | | Data memory | 64 x 4 bits (RAM) | | | General purpose register | | 4 bits x 4 or 8 bits x 2 (memory mapping) | | | | | | | Accumulator | | Three accumulators conforming to handled data length 1-bit accumulator (CY), 4-bit accumulator (A), and 8-bit accumulator (XA) | | | | | | | I/O line | | 22 lines in total • CMOS input ports: 6 lines • CMOS input/output ports (eight pins can directly drive LED's): 12 lines • N-ch open drain input/output ports (which can directly drive LED's): 4 lines | | | | | | ## 1.1 Function Outline (cont'd) | Item | Description | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Pull-up resistor | • 16 pull-up resistor internal control can be performed by using software • Four pull-up resistor internal control can be performed by using mask option (μPD75402A only) | | | Clock output | 1.05 MHz, 524 or 65.5 kHz (at 4.19 MHz) Applicable to remote control output | | | Timer/counter | 8-bit basic interval timer Reference time generation (1.91 or 31.3 ms at 4.19 MHz) Applicable to watchdog timer | | | Serial interface | Eight bits Two transfer modes (clock synchronization 3-wire mode and SBI mode) | | | Interrupt | Three vectored interrupts (one external and two internal) One external testable input | | | Standby | STOP or HALT mode | | | Instruction set | Bit handling instruction (set, clear, test, and Boolean operations) 1-byte relative branch instructions 4-bit operation instructions (addition, Boolean operations, and comparison) 4- and 8-bit data transfer instructions | | | Package | 28-pin plastic DIP 28-pin plastic shrink DIP 44-pin plastic QFP (normal bend) | | #### 1.2 Order Information | order nome | Package | Program memory | |---------------------|-----------------------------|----------------| | μPD75402AC-XXX | 28-pin plastic DIP Mask ROM | | | μPD75402ACT-XXX | 28-pin plastic shrink DIP | 1 1 | | μPD75402AGB-XXX-3B4 | 44-pin plastic QFP | | | μPD75P402C | 28-pin plastic DIP | One time PROM | | μPD75P402CT | 28-pin plastic shrink DIP | | | μPD75P402GB-3B4 | 44-pin plastic QFP | | XXX: ROM code number ## 1.3 Differences between $\mu PD75402A$ and $\mu PD75P402$ Table 1.3-1 lists the differences between the $\mu$ PD75402A and $\mu$ PD75P402. They have the same function except listed in the table and are pin-compatible with each other. Table 1.3-1 Differences between $\mu\text{PD75402A}$ and $\mu\text{PD75P402}$ | Item | μPD75402 <b>A</b> | μPD75P402 | | |-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--| | Program memory - Mask ROM - 1920 x 8 bits | | One time PROM 1920 x 8 bits | | | Port 5 pull-up resistor | Internal pull up resistor is enabled by using mask option. | None | | | Pin connection | One-time PROM write/verify/read pin function (PROM mode) is added to the $\mu PD75P402$ as compared with the $\mu PD75402A$ . (See Chapter 2) | | | | Operation supply voltage range | 2.7 V to 6.0 V 5.0 V ± 10% | | | | Operating temperature range | -40 to +85°C | -10 to +70°C | | | Package | 28-pin plastic DIP 28-pin plastic shrink DIP 44-pin plastic QFP | | | ## 1.4 Block Diagram 11-6-3 #### 1.5 Pin Connections #### 1.5.1 28-pin plastic DIP/shrink DIP ## (1) Normal operation mode SCK P00-P03: Port 0 Serial clock input/output P10-P13: Port 1 SO/SB0 Serial input/output P20-P23: Port 2 SI Serial input PCL Clock output P30-P33: Port 3 P50-P53: Port 5 INT<sub>0</sub> External vectored interrupt P60-P63: Port 6 INT2 External test input X1, X2 Main system clock RESET Reset input $V_{\mathrm{DD}}$ Power supply Ground V<sub>SS</sub> : Ground : Setting the GND from external Note ( ): used by only $\mu$ PD75P402. To share printed circuit board with $\mu PD75P402$ in the $\mu PD75402A$ , set the NC pin to the GND potential. #### (2) PROM mode A0-A14 : Address input O0-O7 : Data input/output CE : Chip enable input OE : Output enable input V\_DD : Power supply V<sub>PP</sub> : Program power supply V<sub>ss</sub> : Ground ## 1.5.2 44-pin plastic QFP (bent lead) #### (1) Normal operation mode Note: ( ): Used by only $\mu$ PD75P402. To share printed circuit board with $\mu$ PD75P402 in the $\mu$ PD75402, set the NC pin which is applicable to the $V_{PP}$ in the $\mu$ PD75402, to GND potential. (2) PROM mode #### 2. PIN FUNCTION The µPD75402A operates in the normal operation mode of the pin function. The μPD75P402 operates in either the normal operation mode (μPD75402A mode) or PROM mode of the pin function. The mode is selected according to the $V_{pp}$ pin level as listed below: | V <sub>PP</sub> | Operation mode | | |---------------------|-----------------------|------------------------| | Low (GND potential) | Normal operation mode | | | High (+5 V) | PROM mode | PROM read mode | | High (+12.5 V) | | PROM write/verify mode | #### 2.1 Normal Operation Mode 2.1.1 P00-P03 (port 0) - input also used for SCK, SO/SB0, and SI P10 and P12 (port 1) - input also used for INT0 and INT2 P00-P03 are 4-bit input port (port 0) input pins. P10 and P12 are 2-bit input pins. The input port pins of ports 0 and 1 are also used for the control signal pins listed in Table 2.1-1. The state of each pin of ports 0 and 1 can always be input regardless of SCK, SO/SB0, SI, INT0, or INT2 pin operation. Every pin of ports 0 and 1 is Schmitt trigger input to prevent noise from causing malfunction. In addition, P10 has an internal noise eliminator using a sampling clock and P12 has an internal noise eliminator using a nalog delay. Internal pull-up resistor can be specified for port 0 in 3-bit units (P01-P03) and port 1 bitwise (P12 only) by using the pull-up resistor specification register (POGA). Internal pull-up resistor cannot be contained in P00 or P10. When RESET is input, every pin is placed in the input port mode. Table 2.1-1 Port 0 and 1 Pins also Used for: | Port 0 | Also used for | Port 1 | Also used for | |--------|---------------|--------|---------------| | P00 | | P10 | INT0 | | P01 | SCK | P12 | INT2 | | P02 | SO/SB0 | | | | P03 | SI | | | 2.1.2 P20-P23 (Port 2) - 3-state input/output also used for PCL P30-P33 (Port 3) - 3-state input/output P50-P53 (Port 5) - N-ch open drain medium voltage (10 V) input/output P60-P63 (Port 6) - 3-state input/output P20-P23, P30-P33, P50-P53, and P60-P63 are input/output pins of 4-bit input/output ports with output latches (ports 2, 3, 5, and 6). Port 2 contains P22 which is also used for the programmable clock output (PCL) function. Port 5 is N-ch open drain medium voltage (10 V) output. Input or output mode can be selected for port 3 bitwise by using the port mode register (PMGA). Input or output mode can be selected for ports 2, 3, and 6 in 4-bit units by using the port mode registers (PMGA and PMGB). Internal pull-up resistor can be specified for ports 2, 3, and 6 in 4-bit units by using software with the pull-up resistor specification register (POGA). Internal pull-up resistor can be specified for µPD75402A port 5 bitwise by using mask option. µPD75P402 port 5 cannot contain internal pull-up resistor. Ports 3, 5, and 6 output high current and can directly drive LED's. When RESET is input, ports 2, 3, and 6 are used as input ports (output high impedance). Port 5 goes high (when internal pull-up resistor is contained) or is placed in high impedance. 2.1.3 SCK, SO/SB0, and SI - 3-state input/output also used for port 0 SCK, SO/SB0, and SI – 3-state input/output pins for serial interface. The pins operate according to how the serial operation mode register (CSIM) is set. Every pin is Schmitt trigger input. When RESET is input, the serial interface stops and the pins are used for input port (port 0). #### 2.1.4 INTO - input also used for port 1 INTO is an external interrupt request input pin. The detection edge can be selected among rising edge, falling edge, and both rising and falling edges by using the external interrupt mode register (IM0). INTO is Schmitt trigger input and contains an internal noise eliminator using sampling clocks. #### 2.1.5 INT2 - input also used for port 1 INT2 is an external test input pin. The detection edge is fixed to the rising edge. INT2 is Schmitt trigger input and contains an internal noise eliminator using analog delay. INT2 is asynchronous input and acknowledged when a signal having a given high level width is input independently of the CPU operation clock. #### 2.1.6 PCL - output also used for port 2 PCL is a programmable clock output pin. It is used to supply a clock to peripheral LSI. PLC output is applicable to carrier signal for remote control. When RESET is input, the clock output function stops and PCL is used for input port (P22). #### 2.1.7 X1 and X2 (crystal) X1 and X2 are internal clock oscillation crystal or ceramic resonator connection pins. Extenal clock can also be supplied. #### (a) Crystal or ceramic oscillation #### (b) External clock Crystal or ceramic resonator (Standard 4.194304 MHz) ## 2.1.8 RESET (reset) RESET is a system reset input pin (active low). It is Schmitt trigger input and contains an internal noise eliminator using analog delay RESET is asynchronous input and acknowledged when a signal having a given low level width is input independently of the CPU operation clock. It takes precedence over every other operation and the system is reset. # 2.1.9 V<sub>DD</sub> V<sub>DD</sub> is a positive power supply pin. 2.1.10 $V_{SS}$ V<sub>SS</sub> is a GND potential pin. ## 2.2 PROM Mode The PROM mode can be selected only for the µPD75P402. #### 2.2.1 A0-A14 (address) - input A0-A14 are 15-bit address input pins in the PROM write/verify or read mode. Since µPD75P402 internal PROM is 2K bytes, the low-order 11 bits (A0-A10) are used for addressing. Fix A11-A14 to high level. #### 2.2.2 O0-O7 (data -- input/output O0-O7 are 8-bit data input/output pins in the PROM write/verify or read mode. #### 2.2.3 CE (chip enable) - input CE is a chip enable signal input pin. 2.2.4 OE (output enable) – input OE is an output enable signal input pin. 2.2.5 $V_{pp}$ $V_{pp}$ is a high-voltage apply pin in the PROM write/verify mode. Be sure to connect the pin to $V_{SS}$ during the normal operation. 2.2.6 $\rm V_{DD}$ $\rm V_{DD}$ is a power supply voltage apply pin. $\rm 2.2.7~V_{SS}$ $\rm V_{SS}$ is a GND potential pin. ## 2.3 Pin Input and Output Circuits The pin input and output circuits are shown schematically. Table 2.3-1 Pin Input/Output Types | Table 2.3-1 Fill input/Output Types | | | | | | | |-------------------------------------|----------------------------------------------------------------------------------------|--|--|--|--|--| | Input/output type | | | | | | | | μPD75402A | μPD75P402 | | | | | | | ( | 3 | | | | | | | (Ē) | –A | | | | | | | Œ | -В | | | | | | | ® | -c | | | | | | | B | | | | | | | | ®−c | | | | | | | | E-B | | | | | | | | C-D | | | | | | | | E–B | | | | | | | | М | M–A | | | | | | | E-B | | | | | | | | B | | | | | | | | | Input/ou µPD75402A (F) (F) (B) (G) (B) (C) (B) (C) (C) (C) (C) (C) (C) (C) (C) (C) (C | | | | | | Remarks: ( ): Schmitt trigger input The $\mu PD75402A$ pin input / output circuits are shown in schematic drawings. (1) Type A (for Type E - B) CMOS standard input buffer (2) Type B Schmitt trigger input with hysteresis characteristic (3) Type B - C (4) Type D (for Type E - B, F - A) Push-pull output where output can be placed in high impedance (both P and N channels are turned off). P.U.R.: Pull-Up Resistor ## (6) Type F - A P.U.R.: Pull-Up Resistor ## (7) Type F - B P.U.R.: Pull-Up Resistor ## (8) Type M P.U.R.: Pull-Up Resistor ## (9) Type M - A Middle-high voltage input buffer (+10 V voltage) #### 3. ARCHITECTURE FEATURES AND MEMORY MAP The μPD75402A architecture is a subset of the μCOM-75X architecture. The features are described here. #### 3.1 Data Memory Bank Configuration and Addressing Mode #### 3.1.1 Data memory bank configuration The $\mu$ PD75402A data memory space consists of banks. The $\mu$ PD75402A contains general purpose RAM (64 x 4 bits) at address 000H-03FH (bank 0) and peripheral hardware (such as input/output ports and serial interface) at addresses F80H-FFFH (bank 15), as listed in Table 3.1-1. To address the data memory space of 12-bit addresses, the low-order 8-bit address part is specified directly or indirectly by using an instruction. The high-order 4-bit address part is determined by the memory bank (MB) to be accessed. The µPD75402 contains banks 0 and 15 only and does not contain the memory bank switching function. The memory bank to be accessed is determined by the addressing mode and the specified address. (See tables 3.1-1 and 3.1-2). Table 3.1-1 Data Memory Configuration and Address Range in Each Addressing Mode Table 3.1-2 Addressing Mode List | Addressing mode | Representation format | Specified address | | | | |-------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 1-bit direct addressing | mem.bit | Bit specified in bit, of address specified in mem. When mem = 00H-3FH, memory bank 0 is accessed. When mem = 80H-FFH, memory bank 15 is accessed. | | | | | 4-bit direct addressing | | Address specified in mem. When mem = 00H-3FH, memory bank 0 is accessed. When mem = 80H-FFH, memory bank 15 is accessed. | | | | | 8-bit direct addressing | mem | Address specified in mem (mem is an even address). When mem = 00H-3FH, memory bank 0 is accessed. When mem = 80H-FFH, memory bank 15 is accessed. | | | | | 4-bit register indirect addressing | @ HL | Address indicated by the HL contents, of memory bank 0.<br>HL = 00H-3FH | | | | | Bit manipulation addressing fmem. t | | Bit specified in bit, of address specified in fmem, of memory bank 1 fmem = FB0H-FBFH (interrupt hardware) fmem = FF0H-FFFH (input/output ports) | | | | | Stack addressing | _ | Addressing indicated by SP, memory bank 0. SP = 20H-3FH | | | | #### 3.1.2 Data memory addressing mode The $\mu$ PD75402A provides the six data memory space addressing modes listed in Table 3.1-2 for efficient addressing for each bit length of the data to be processed. $\label{local-policy} Unlike other \mu COM-75X is a mily devices, the \mu PD75402A enables you to perform programming without taking care of memory bank switching because the memory bank to be accessed is fixed by the addressing mode.$ ## (1) 1-bit direct addressing (mem.bit) The 1-bit direct addessing mode directly specifies each bit of the data memory space in the instruction operand. Memory bank 0 (MB = 0) is specified when the address specified in the mem operand is any of 00H-3FH or memory bank 15 (MB = 15) when the address specified in the mem operand is any of 80H-FFH. Thus, the mode enables addressing all bits of both the general purpose RAM area (00H-3FH) and peripheral hardware area (FF0H-FFFH). However, the bits that can be handled bitwise in the peripheral hardware area are limited. (See Table 3.2.2). The addressing mode is applicable to bit set and clear instructions (SET1 and CLR1) and bit test instructions (SKT and SKF). Example: Set FLAG1, clear FLAG2, and check whether or not FLAG3 is set to 0. FLAG1 EQU 03FH.1 ; Address 3FH bit 1 FLAG2 EQU 027H.2 ; Address 27H bit 2 FLAG3 EQU 017H.0 , Address 17H bit 0 SET1 FLAG1 ; FLAG $\leftarrow$ 1 CLR1 FLAG2 ; FLAG $\leftarrow$ 0 SKF FLAG3 ; FLAG = 0 ? #### (2) 4-bit direct addressing (mem) The 4-bit direct addressing mode directly specifies all the data memory space in 4-bit units in the instruction operand. Memory bank 0 (MB = 0) is specified when the address specified in the mem operand is any of 00H-3FH or memory bank 15 (MB = 15) is specified when the address is any of 80H-FFH. Thus, the mode enables addressing both the general purpose RAM area (000H-03FH) and peripheral hardware area (FF0H-FFFH). The addressing mode is applicable to the MOV, XCH, INCS, IN, and OUT instructions. Example 1: Input port 2 and store in "DATA1". DATA1 EQU 2FH ; "DATA1" is address 2FH IN A, PORT2 ; $A \leftarrow PORT2$ MOV DATA1, A ; (DATA1) $\leftarrow$ A Example 2: Output "BUFF" data into port 5. BUFF EQU 01AH ; "BUFF" is address 01AH MOV A, BUFF ; $A \leftarrow (BUFF)$ OUT PORT5, A ; PORT5 $\leftarrow$ A #### (3) 8-bit direct addressing (mem) The 8-bit direct addressing mode directly specifies all the data memory space in 8-bit units in the instruction operand. Memory bank 0 (MB = 0) is specified when the address specified in the mem operand is any of 00H-3FH or memory bank 15 (MB = 15) is specified when the address is any of 80H-FFH. Thus, the mode enables addressing both the general purpose RAM area (000H-03FH) and peripheral hardware area (FF0H-FFFH). However, the peripheral hardware area addresses that can be handled in 8-bit units are limited. (See. Table 3.2-2.) The addressing mode is applicable to the MOV and XCH instructions. Example 1: Store 8-bit data of the serial interface shift register (SIO) in addresses 20H and 21H. DATA EQU 020H MOV XA, SIO ; XA ← SIO MOV DATA, XA ; $(21H) \leftarrow X$ , $(20H) \leftarrow A$ Example 2: Read 8-bit data input to SIO into the XA register pair. At the same time set the transfer data stored in the XA register pair and give the transfer start instruction. XCH XA, SIO ; XA ↔ SIO #### (4) 4-bit register indirect addressing (@HL) The 4-bit register indirect addressing mode indirectly specifies the data memory space in 4-bit units by using the HL register pair. Memory bank 0 (MB = 0) is always addressed in the addressing mode. Thus, only the general purpose RAM area (000H-03FH) can be addressed. The peripheral hardware area cannot be addressed. Store data in the range of 00H-3FH in the HL register pair. The addressing mode has wide applications such as data transfer, operations, and comparison. Data memory space addresses can be updated as desired by using the addressing mode and HL register pair increment and decrement instructions (INCS and DECS) in combination. Example: Set all the 20H-2FH contents to FH. $\begin{array}{cccc} & \mathsf{MOV} & \mathsf{HL}, \#2\mathsf{FH} \\ & \mathsf{MOV} & \mathsf{A}, \#0\mathsf{FH} & ; \; \mathsf{A} \leftarrow \mathsf{FH} \\ \mathsf{LOOP:} & \mathsf{MOV} & @\mathsf{HL}, \mathsf{A} & ; \; (\mathsf{HL}) \leftarrow \mathsf{A} \end{array}$ DECS L BR LOOP Fig. 3.1-1 General Purpose RAM Address Update Method (5) Specific address bit handling addressing (fmem. bit) This addressing mode directly specifies each bit of the input/output ports and flags such as interrupt flags of peripheral hardware in the instruction operand. Thus, the addressing mode is applicable to data memory addresses FB0H-FBFH and FF0H-FFFH. The 1-bit direct addressing mode (mem. bit) is applicable only to bit set, clear, and test instructions; the specific address bit handling addressing mode enables diversified bit handling such as Boolean processing (AND1, OR1, and XOR1 instructions) and test and clear (SKTCLR instruction) as well as bit set, reset, and test instruction handling. Example 1: Test basic interval timer interrupt request flag (IRQBT). If the flag is set, clear IRQBT and clear the P63 pin level. Example 2: If both P30 and P61 are set to 1, clear P53. ## (6) Stack addressing The stack addressing mode is used for save and restore operation when interrupt service or subroutine is performed. The data memory is indirectly addressed by using an 8-bit stack pointer (SP). Memory bank $0 \, (\text{MB} = 0)$ is always addressed in the stack addressing mode. Since the high-order three bits of the stack pointer are fixed to 001, the 020H-03FH area can only be addressed. The stack addressing mode is also used to save and restore registers when PUSH and POP instructions are executed. Caution: Unlike the µPD75402A, the evaluation chip installed on the evaluation board enables the stack addressing mode to address all the area of memory bank 0. To eliminate the difference during the evaluation, set the stack pointer to a value so as not to access exceeding the 20H-3FH range. Example 1: Save and restore registers in subroutine processing. SUB: PUSH XA PUSH HL : : POP HL POP XA RET Example 2: Transfer the HL register pair contents to the XA register pair. PUSH HL POP XA; XA ← HL Example 3: Branch to the address indicated by [XAHL] register. PUSH HL PUSH XA RET ; Branch to address XAHL #### 3.2 Memory Mapped I/O The µPD75402A adopts memory mapped I/O which maps peripheral hardware such as input/output ports and serial interface in data memory space addresses F80H-FFFH as listed in Table 3.1-1. Thus, special instructions to control the peripheral hardware are not provided. The peripheral hardware is all controlled by using memory handling instructions. (Some hardware control mnemonics are provided to easily understand programs.) The addressing modes listed in Table 3.2-1 can be used when the peripheral hardware is handled. Table 3.2-1 Applicable Addressing Modes when Peripheral Hardware is Handled | | Applicable addressing mode | Applicable hardware | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------|--|--|--| | bit manipulation | Direct addressing. Specify the bit to be handled in mem.bit | All hardware devices where bit handling can be performed. | | | | | in the state of th | Direct addressing. Specify the bit to be handled in fmem. bit | IEXXX, IRQXXX, PORTn.X | | | | | 4-bit handling | Direct addressing. Specify the address to be handled in mem. | All hardware devices where 4-bit handling can be performed | | | | | 8-bit handling | Direct addressing. Specify the address to be handled in mem (mem is an even address). | All hardware devices where 8-bit handling can be performed | | | | Table 3.2-2 lists the $\mu PD75402A$ I/O map. The items in the table mean: - Abbreviation: Name indicating the internal hardware address. It can be entered in the instruction operand field. However, IME cannot be entered. - Number of bits that can be handed. Indicates the number of applicable bits to be processed when the hardware device is handled. Symbols such as R/W indicate whether or not the hardware device can be read/written. - R/W: Read/written can be made. R: Read only can be made. W: Write only can be made. - · Bit handling addressing: Indicates the applicable bit handling addressing when the hardware device is handled bitwise. Table 3.2-2 μPD75402A I/O Map | | Hardware name (abbreviation) | | | Number of bits that can be manipulated | | | Bit manipulation | | | |---------|------------------------------------------|--|--|----------------------------------------|-------|-------|------------------|----------------------------------------|---------| | Address | b3 b2 b1 b0 | | | | 1-bit | 4-bit | 8-bit | addressing | Remarks | | F80H | OH Stack pointer (SP) | | | _ | _ | | | Bit 0 is fixed to 0. | | | | | | | _ | | W | | | | | F85H | Basic interval timer mode register (BTM) | | | _ | W | - | | Be sure to write 11 into bits 1 and 0. | | | F86H | Basic interval timer (BT) | | | _ | _ | R | | | | | | | | | _ | | | | * * * * * * * * * * * * * * * * * * * | | Table 3.2-2 µPD75402A I/O Map (cont'd) | | Hardware name (abbreviation) | | | | Number of bits that can be manipulated | | | Bit manipulation | | |---------------------------------------|---------------------------------|--------------|------------|----------|----------------------------------------|-------|-----------|------------------------------|-------------------------------------------| | Address | b3 | b2 | b1 | b0 | 1-bit | 4-bit | 8-bit | addressing | Remarks | | FB2H | (IME) | | | | _ | | | | Handle it by using EI and DI instructions | | FB3H | Proces<br>(PCC) | sor clock | control | register | _ | W | _ | | | | FB4H | INT0 mode register (IM0) | | | | _ | w | _ | | Bit 2 is fixed to 0. | | FB8H | 0 | 0 | IEBT | IRQBT | R/W | R/W | _ | | | | FBDH | 0 | 0 | IECSI | IRQCSI | R/W | R/W | _ | fmem. bit | | | FBEH | 0 | 0 | IE0 | IRQ0 | R/W | R/W | | 1.1 | | | FBFH | 0 | 0 | IE2 | IRQ2 | R/W | R/W | | | | | FD0H | Clock of<br>(CLOM | output mo | ode regis | ster | <del>-</del> | w | _ | 7 | | | FDCH | Pull-up | resistor | specifica | ation | | | | | | | | | r A (POC | | | _ | | w | 1 | | | FE0H | Serial | operation | mode r | egister | _ | _ | | | | | FE1H | (CSIM) | COI | WUP | 0 | Note 1 | _ | w | mem. bit | Be sure to write 0 into bit 0. | | FE2H | CSIE | <del> </del> | CMDT | RELT | | | | | | | | SBI co | ntrol regi | ster (SB | IC) | Note 2 | | _ | mem. bit | All bits can be handled only bitwise | | FE3H | | ACKD | | | Note 3 | | | | Only bitwise | | FE4H | | | | | _ | R/W | | | | | · · · · · · · · · · · · · · · · · · · | Serial I/O shift register (SI0) | | | | | | | | | | FE6H | - Slave address register (SVA) | | | _ | _ | 147 | | Be sure to write 11000 | | | | Slave | address | register ( | SVA) | _ | | W | | into the high-order five bits. | | FE8H | Port mode register group A | | | | | | 14. | | | | | (PMGA | | | | _ | | W | | | | FECH | Port m | ode regis | ster grou | рΒ | _ | _ | w | | | | | (PMGE | 3) | | | | _ | ** | | | | FF0H | Port 0 (PORT 0) | | | | R | R | | | : | | FF1H | Port 1 (PORT 1) | | | R | R | | | Bits 3 and 1 are fixed to 0. | | | FF2H | Port 2 (PORT 2) | | | R/W | R/W | | fmem. bit | | | | FF3H | Port 3 | (PORT | 3) | | R/W | R/W | | intent. Dit | | | FF5H | Port 5 (PORT 5) Port 6 (PORT 6) | | | | R/W | R/W | _ | | | | FF6H | | | | | R/W | R/W | _ | | | Note 1: Bits 3 and 1 = W, bit 2 = R Note 2: Bits 3 and 2 = R, bits 1 and 0 = W Note 3: Bits 3 and 1 = R/W, bit 2 = R, bit 0 = W Remarks: IEXXX is an interrupt enable flag., IRQXXX is an interrupt request flag. # 4. INTERNAL CPU FUNCTION #### 4.1 Program Counter The program Counter (PC) is an 11-bit binary counter which retains program memory address information. Fig. 4.1-1 Program Counter Format The program counter operates as follows: - · When normal operation is performed - Each time one instruction is executed, the program counter contents are automatically incremented according to the number of bytes of the instruction. - · When branch instruction (BR or BRCB) is executed - The immediate data indicating the branch destination address is stored in the PC. - · When subroutine call instruction (CALLF) is executed or vectored interrupt occurs - The PC contents are saved in stack memory, then the branch destination address is stored in the PC. - When return instruction (RET, RETS, or RETI) is executed - The stack memory contents are restored in the PC. - When RESET is input The low-order three bits of program memory address 000H are stored in PC10-PC8 and the address 001H contents are stored in PC7-PC0, then initialization is made. Program can be started at any desired address. #### 4.2 Program Memory (ROM) - 1920 words x 8 bits The program memory (ROM) is mask programmable ROM consisting of 1920 word x 8 bits. It stores programs and data such as table data. The program memory is addressed by the program counter. The table data in ROM can also be read by using a table reference instruction (MOVT). A branch can be made to the entire program area by using a branch or subroutine call instruction. (See Fig.4.2-1) A relative branch instruction (BR \$addr) enables a branch in the range of (–15 to +16) from the address indicated by the PC after instruction execution. Program memory addresses are 000H-77FH. The addresses shown in Fig. 4.2-1 are specially assigned. All area except 00H or 001H can be used as a normal memory area. Fig. 4.2-1 Program Memory Map # 4.3 Data Memory The data memory consists of general purpose static RAM (memory bank 0) and peripheral hardware area (memory bank 15) as shown in Fig. 4.3-1. The general purpose static RAM contains $64 \times 4$ bits of memory bank 0. It stores process data and is also used as stack memory when a subroutine instruction or interrupt is executed. Specific addresses of the general purpose RAM are assigned as general purpose registers which are handled by using general purpose register access instructions. Addresses 020H-03FH of memory bank 0 can be used as a stack area. Although one address of general purpose RAM consists of four bits, data can be handled in 8-bit units by using 8-bit memory handling instructions or bitwise by using bit handling instructions. Specify even addresses in the 8-bit handling instructions. Peripheral hardware is mapped in F80H-FFFH of memory bank 15 (peripheral hardware area). Like general purpose RAM, it can be accessed by using memory handling instructions. However, the number of bits that can be handled for each address of the peripheral hardware is limited. (See table 3.2-2) Data memory is not contained in addresses to which peripheral hardware is not assigned in Table 3.2-2. Do not access the addresses. Since general purpose RAM becomes undefined at reset, normally it should be initialized to 0 (RAM clear) at the beginning of a program, or an unexpected bug may be caused. Be sure to initialize the general purpose RAM to 0. Example: Clear the entire general purpose RAM area (00H-3FH). (However, FFH remains in the HL register pair). MOV HL, #3FH MOV A, #0H LOOP: MOV @HL, A ; Clear 00H-3FH DECS L BR LOOP DECS H BB LOOP Fig. 4.3-1 Data Memory Map # 4.4 General Purpose Registers - 4 x 4 bits The general purpose registers are four 4-bit registers H, L, X, and A which are assigned to specific addresses of the data memory. Each general purpose register is handled in 4-bit units. In addition, HL and XA form register pairs which are handled in 8-bit units. The HL register pair can also be used as a data pointer for indirectly addressing memory. The general purpose register area can be addressed and accessed as normal RAM regardless of whether or not it is used as registers. | 1 | | | |---|-----|-----| | ١ | X | A | | l | 01H | 00Н | | I | | | | 1 | Н | L | | | 03H | 02H | Remarks: The number shown in the lower right corner is the data memory address to which the register is assigned. Fig. 4.4-1 General Purpose Register Configuration Fig. 4.4-2 Register Pair Configuration #### 4.5 Accumulators On the $\mu$ PD75402A, the A register and XA register pair function as accumulators. 4-bit data processing instructions are executed centering around the A register; 8-bit data processing instruction are executed centering around the XA register pair. When bit handling are executed, the carry flag (CY) functions as a bit accumulator. Fig. 4.5-1 Accumulators # 4.6 Stack Pointer (SP) - 8 bits The $\mu$ PD75402A uses general purpose RAM as stack memory (LIFO). The stack pointer (SP) is an 8-bit register which retains the stack memory area top address information . Fig. 4.6-1 shows the stack pointer (SP) format. Since the high-order three bits of the SP are fixed to 001, general purpose RAM addresses 020H-03FH are used for the stack area. The SP is decremented before write (save) operation into stack memory and incremented after read (restore) operation from the stack memory. Figs. 4.6-2 and 4.6-3 show data saved in and restored from the stack memory. The initial value is set in the SP by using an 8-bit data transfer instruction to determine the stack area. The SP contents cannot be read. 0 is always written into SP bit 0. It is recommended to write 40H into the SP for initialization and use the area from the highest address of internal RAM (03FH) to lower addresses as the stack area. When RESET is input, the SP contents become undefined. Be sure to initialize the SP to any desired value by using the program initialization routine. Caution: Unlike the µPD75402A, the evaluation chip installed on the evaluation board enables addressing all the area of 000H-0FFH. To eliminate the difference during evaluation, set the SP to a value so as not to access exceeding the range of 020H-03FH. Fig. 4.6-1 Stack Pointer Format Fig. 4.6-2 Data Saved in Stack Memory Fig. 4.6-3 Data Restored from Stack Memroy # 4.7 Program Status Word (PSW) - 8 bits The program status word (PSW) consists of flags related closely to processor operation. Fig. 4.7-1 shows the program status word (PSW) format. When an interrupt is acknowledged, the PSW contents are saved in the stack memory in 8-bit units. When a RETI instruction is executed, the PSW contents are restored from the stack memory in 8-bit units. (See Figs. 4.6-2 and 4.6-3). Fig. 4.7-1 Program Status Word Format Since the PSW is not assigned to the data memory space, the flags cannot be handled by using memory handling instructions. However, only the carry flag (CY) can be handled by using its dedicated instructions. When RESET is input, IST0 is set to 0 and SK0-SK2 and CY become undefined. (1) Carry flag (CY) The carry flag is a 1-bit flag to store overflow occurrent information when an operation instruction with carry (ADDC) is executed. The carry flag also has the bit accumulator function. Boolean algebra operation is performed between the bit accumulator and data memory specified in the bit address, and the result can be stored in the bit accumulator. When the RESET signal is generated, the carry flag becomes undefined. | Ta | ble 4.7 | -1 ( | Carry | Flag | Hand | ling | Inst | ructi | ons | |----|---------|------|-------|------|------|------|------|-------|-----| | | | | | | | | | | | | | Instruction (mnemonic) | Carry flag operation or processing | |----------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | Carry flag handling dedicated instruction | SET1 CY<br>CLR1 CY<br>NOT1 CY<br>SKT CY | Set CY to 1 Clear CY Invert the CY contents Skip if CY contains 1 | | Bit Boolean instructions AND1 CY, fmem. bit OR1 CY, fmem. bit XOR1 CY, fmem. bit | | The specified bit contents and CY contents are ANDed (ORed, or exclusively ORed) together, and the result is stored in CY. | | Interrupt service | When interrupt is executed RETI | CY is saved in stack memory in parallel with other seven PSW bits. CY is restored from stack memory in parallel with other PSW bits. | Example: AND address 3FH bit 3 and P33 together and store the result in CY. > SET1 CY ; CY ← 1 SKT 3FH.3 ; Skip if address 3FH bit 3 is set to 1 CLR1 CY ; CY ← 1 AND1 CY, PORT3.3 : CY ← CY ∧ P33 (2) Skip flag (SK2, SK1, SK0) The skip flag stores the skip state. It is automatically set or cleared by the CPU which executeds a given instruction. The skip flag cannot directly be handled by user. (3) Interrupt status flag (IST0) The interrupt status flag stores the status of the current processing being performed. (See Table 6.3-2 for details.) It cannot directly be handled by the user in a program. **Table 4.7-2 Interrupt Status Flag Indication Contents** | IST0 | Status of current processing being performed | Processing contents and interrupt control | | |------|----------------------------------------------|------------------------------------------------------------------------------------|--| | 0 | Status 0 | Normal program processing is being performed. Every interrupt can be acknowledged. | | | 1 | Status 1 | 1 Interrupt service is being executed. No interrupts can be acknowledged. | | When an interrupt is acknowledged, the IST0 contents are saved in stack memory as a part of PSW, then automatically set to 1. When a RETI instruction is executed, IST0 is set to 0. Since IST0 cannot be handled by using an instruction, it is always set to 1 during interrupt service. Thus, interrupts are not multiplexed and all interrupt requests occuring during the interrupt service are held until the interrupt service being executed terminates. (See 6. for details). #### 5. PERIPHERAL HARDWARE FUNCTION # 5.1 Digital Input/Output Ports The µPD75402A contains internal digital input/output ports (ports 0-3, 5 and 6). The µPD75402A adopts memory mapped I/O which maps all input/output ports in the data memory space. All data memory handling instructions are applicable to the ports; diversified bit handling as well as 4-bit input/output can be performed. Caution: The µPD75402A does not enable 8-bit input/output using ports in pairs. | viation | |---------| | | | 0 | | 1 | | 2 | | 3 | | | | 5 | | 6 | | | Fig. 5.1-1 Digital Input/Output Port Data Memory Addresses 5.1.1 Types, features, and configuration of digital input/output ports Table 5.1-1 lists the digital input/output port types. Figs. 5.1-2 to 5.1-5 show the port configuration. Table 5.1-1 Digital Input/Output Port Types and Features | Port (abbreviation) | Function | Operation and features | Remarks | | |---------------------|--------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--| | PORT0<br>PORT1 | 4-bit input | Can always be read or tested regardless of the operation mode of the SO/SB0, SI, SCK, INT0 or INT2 pin. | The pins <u>are also used for SO/SB0, SI, SCK, INT0 and INT2.</u> (See 1.) | | | PORT3 (Note) | 4-bit input/output | Can be placed in the input or output mode bitwise. | | | | PORT2<br>PORT6 | | Can be placed in the input or output mode in 4-bit units. | The P22 (port 2) pin is also used for PCL. | | Table 5.1-1 Digital Input/Output Port Types and Features (Cont'd) | Port (abbreviation) | Function | Operation and features | Remarks | |---------------------|---------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------| | PORT5 (Note) | 4-bit input/output (N-ch open drain 10 V voltage) | Can be placed in the input or output mode in 4-bit units. | Internal pull-up resistor can be specified bitwise by using mask option. (µPD75402A only) | Note: LED can be directly driven. The $\mu$ PD75402A enables an internal pull-up resistor to be contained in all port pins except P00 or P10. The $\mu$ PD75P402 enables internal an pull-up resistor to be contained in port pins except P00, P10 or P50-P53. (See 5.5) P10 is also used for the external vectored interrupt input pin and contains an internal noise eliminator using sampling clocks. (See 6.2 for details). When RESET is input, the output latches of ports 2, 3, 5 and 6 are cleared, the output buffers are turned off, and the input mode is entered. Figure 5.1-2 Configuration of Ports 0 or 1 Figure 5.1–3 Configuration of port3 (n = 0-3) Figure 5.1-4 Configuration of Port 2 or 6 Note: The input or output mode is selected for port 2 by using PMGB bit 2 (PM2) and for port 6 by using PMGA bits 4 - 7 (PM60-PM63). Figure 5.1-5 Configuration of Port 5 ### 5.1.2 Input/output mode setting The input or output mode is selected for each input/output port as shown in Fig. 5.1-6. The input or output mode can be selected for port 3 bitwise by using the port mode register A (PMGA). The input or output mode is selected for ports 2 and 5 by using PMGB and for port 6 by using PMGA in 4-bit units. Each port serves as an input port when its corresponding port mode register bit is set to 0; it serves as an output port when 1. The output latch contents are output to the output pin at the same time the output mode is selected by setting the port mode register. Thus, the output latch contents must be preset to the required value before the output mode is selected. Port mode registers A and B are set by using 8-bit memory handling instructions. When the RESET signal is generated, all bits of the port mode registers are cleared; the output buffers are turned off and all ports are placed in the input mode. # Port mode register B | | Selection | |---|--------------------------------| | 0 | Input mode (output buffer off) | | 1 | Output mode (output buffer on) | Note: Select the input or output mode for port 6 in 4-bit units. Be sure to write 0000 or 1111 into PMGA bits 7-4. # Fig. 5.1-6 Port Mode Register Formats # 5.1.3 Digital input/output port handling instructions Since all the input/output ports contained in the µPD75402A are mapped in the data memory space, all data memory handling instructions can be used. Table 5.1-2 lists the data memory handling instruction particularly useful for input/output pin handling and the instruction application. (1) Bit handling instructions Specific address bit direct addressing (fmem.bit) can be used for all digital input/output ports. Example: OR P50 and P31 together and output the result to P61. SKT CY BR CLRP SET1 PORT6.1 CLR1 PORT6.1 : P61 ← 0 : P61 ← 1 # (2) 4-bit handling instructions All 4-bit memory handling instructions such as MOV, XCH, ADDS, and INCS, as well as the IN and OUT instructions, can be used. Example 1: Output the accumulator contents to port 3. OUT PORT3, A Example 2: Add the accumulator value to the data output to port 5 and output the result to port 5. MOV HL, #PORT5 ; A ← A+PORT5 A, @HL ADDS CLRP: NOP MOV @HL. A : PORT5 ← A #### Table 5.1-2 Input/Output Pin Handling Instruction Lins | | | Port 0 | Port 1 | Port 2 | Port 3 | Port 5 | Port 6 | |------|---------------|--------|--------|--------|--------|--------|--------| | IN | A, PORTn | | 0 | | | | | | OUT | PORTn, A | _ | | | ( | ) | | | SET1 | PORTn.bit | | _ | ν. | ( | ) | | | CLR1 | PORTn.bit | _ | | | ( | ) | | | SKT | PORTn.bit | | 0 | | | | | | SKF | PORTn.bit | | 0 | | | | | | AND1 | CY, PORTn.bit | | 0 | | | | | | OR1 | CY, PORTn.bit | | 0 | | | | | | XOR | CY, PORTn.bit | | 0 | | | | | ### 5.1.4 Digital input/output port operation When a data memory handling instruction is executed for each digital input/output port, the port (pin) operation varies depending on which mode, input or output mode, is selected. (See Table 5.1-3.) This is because pin data is read onto the internal data bus in the input mode and output latch data in the output mode, as understood from the input/output port configuration. (1) Operation when port (pin) is placed in input mode When a test instruction such as SKT or an instruction to read port data onto the internal bus in four bits (IN, MOV, or bit operation instruction) is executed, pin data is handled. When an instruction to transfer the accumulator contents to a port in four bits (OUT or MOV instruction) is executed, the accumulator data is latched in the output latch. The output buffer remains off. When an XCH instruction is executed, pin data is input to a given accumulator and the accumulator data is latched in the output latch. The output buffer remains off. When INCS instruction is executed, data resulting from adding 1 to pin data (four bits) is latched in the output latch. The output buffer remains off. When an instruction to rewrite the data memory bitwise, such as the SET1, CLR1, or SKTCLR instruction, is executed, the output latch of the specified bit can be rewritten as designated by the instruction, but the output latch contents of other bits become undefined. # (2) Operation when port (pin) is placed in output mode When a test instruction, bit input instruction , or instruction to read port data onto the internal bus in four bits is executed, the outure latch contents are handled. When an instruction to transfer the accumulator contents in four bits executed, output latch data is rewritten and output from the pin at the same time. When an XCH instruction is executed, the output latch contents are transferred to a given accumulator and the accumulator contents are latched in the output latch and output from the pin. When INCS instruction is executed, data resulting from adding 1 to the output latch contents is latched in the output latch and and output from the pin. When a bit output instruction is executed, the specified output latch bit is rewritten and output from the pin. Table 5.1-3 Operation when Input/Output Port is Handled | | - | Port (pin) operation | | | |------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--| | Execute | d instruction | Input mode | Output mode | | | SKT<br>SKF | PORTn.bit<br>PORTn.bit | Test pin data | Test output latch | | | AND1<br>OR1<br>XOR1 | CY, PORTn.bit<br>CY, PORTn.bit<br>CY, PORTn.bit | Perform operation between pin data and CY | Perform operation between output latch data and CY | | | IN<br>MOV | A, PORTn<br>A, PORTn | Transfer pin data to accumulator | Transfer output latch data to accumulator | | | OUT<br>MOV | PORTn, A<br>PORTn, A | Transfer accumulator data to output latch (Output buffer remains off.) | Transfer accumulator data to output latch and output from pin | | | XCH | A, PORTn | Transfer pin data to accumulator. Transfer accumulator data to output latch. (Output buffer remains off.) | Exchange data between output latch and accumulator | | | INCS | PORTn | Latch data resulting from adding 1 to pin data in output latch | Increment the output latch contents by one | | | SET1<br>CLR1<br>SKTCLR | PORTn.bit<br>PORTn.bit<br>PORTn.bit | Although the specified bit output latch is rewritten as designated by the instruction, the output latch of other bits is undefined. | Change the output pin state according to a given instruction | | # 5.1.5 Internal pull-up resistor The $\mu PD75402A$ enables an internal pull-up resistor to be contained in port pins except P00 or P10. Internal pull-up resistors can be specified by using software or mask option as listed in Table 5.1-4. The pull-up resistor specification register (POGA) to specify internal pull-up resistor in ports 0-3 and 6 is a write-only 8-bit register. Fig. 5.1-7 shows the POGA format. POGA is set by using an 8-bit write instruction. It cannot be read or handled bitwise. When RESET is input, POGA is cleared. Internal pull-up resistor in port 3 can be specified only for the pins for which the input mode is selected. The pins for which the output mode is selected do not contain an internal resistor regardless of how POGA is set. Table 5.1-4 Internal Pull-up Resistor Specification Method for Ports | Port (pin name) | Internal pull-up resistor specification method | Specification bit | |----------------------------------------------------------|------------------------------------------------|----------------------------| | Port 0 (P01-P03) (Note 1) | Use software in 3-bit units | POGA.0 | | Port 1 (P12) (Note 1) | Use software in 1-bit units | POGA.1 | | Port 2 (P20-P23)<br>Port 3 (P30-P33)<br>Port 6 (P60-P63) | Use software in 4-bit units | POGA.2<br>POGA.3<br>POGA.6 | | Port 5 (P50-P53) | Use mask option bitwise | _ | Note 1: Internal pull-up resistor cannot be contained in the P00 or P10 pin. | | Selection | |---|--------------------------------------------| | 0 | Internal pull-up resistor is not contained | | 1 | Internal pull-up resistor is contained | Fig. 5.1-7 Pull-up Resistor Specification Register Format Fig. 5.1-8 shows the pull-up resistor change timing when the pull-up resistor specification registre (POGA) is set. Remarks: $\phi_0$ to $\phi_3$ are internal operation timing clocks Fig. 5.1-8 Internal Pull-up Register Change Timing After internal pull-up resistor is specified by rewriting POGA, consider the extenal load capacitance and execute NOP instruction, etc., to stabilize the pin level before executing an input/output instruction. Example: Input after internal pull-up resistor is specified for port 1. 5.1.6 Digital input/output port input/output timings Fig. 5.1-9 shows the data output timing to an output latch and the pin or output latch data read timing onto the internal bus. #### 5.2 Clock Generator The clock generator supplies clocks to the CPU and peripheral hardware controls the CPU operation mode. # 5.2.1 Clock generator configuration Fig. 5.2-1 shows the clock generator block diagram. Remarks: 1. $f_{\chi\chi}$ = crystal or ceramic oscillation frequency 2. $f_{\chi}$ = external clock frequency 3. The instruction marked an asterisk (\*) is executed. - 4. PCC: Processor clock control register Fig. 5.2-1 Clock Generator Block Diagram #### 5.2.2 Clock generator function and operation The clock generator generates the CPU clock and clocks supplied to the peripheral hardware and controls the CPU operation mode such as the standby mode. The clock generator operation is determined by the processor clock control register (PCC). When RESET is input, PCC is set to 0000 and the µPD75402A operates in the low speed mode (15.3 µs at 4.19 MHz). Clocks are provided by dividing system clock generator output (f<sub>xx</sub> (crystal or ceramic oscillation) or f<sub>x</sub> (external clock)) by the divider to the peripheral hardware. In the description to follow, only fxx is used to represent the clock speed. Replace it with fx for the external clock. Block operation is explained below: (1) Processor clock control register (PCC) The processor clock control register (PCC) is a 4-bit register to select the CPU clock and control the CPU operation mode. Fig. 5.2-2 shows the PCC format. When bit 3 or 2 is set to 1, the standby mode (STOP or HALT) is selected. When the standby mode is released by the standby release signal, bits 3 and 2 are automatically cleared and normal operation mode is selected. (For details, see Chapter 7.) PCC bit 1 is set by using a 4-bit memory handling instruction. Bits 3 and 2 are set to 1 by using the STOP and HALT instructions, respectively. When RESET is input, the PCC is cleared (0000). Example 1: Set machine cycle to 1.91 µs (at 4.19 MHz). > MOV MOV A. #0010B PCC, A Example 2: Select the STOP mode. (Be sure to write a NOP instruction following the STOP or HALT instruction.) STOP NOP Address Abbreviation 3 2 0 PCC2 FB3H PCC3 PCC1 PCC0 PCC CPU clock selection bits | | | The values enclosed in parentheses are applied when $f_X = 4.19 \text{ MHz}$ | | | | | | |---|---|------------------------------------------------------------------------------|---------------|--|--|--|--| | | | CPU clock frequency | machine cycle | | | | | | 0 | 0 | $\Phi = f_{\chi}/64 (65.5 \text{ kHz})$ 15.3 µs | | | | | | | 0 | 1 | Undefined | <u> </u> | | | | | | 1 | 0 | $\Phi = f_{\chi}/8 \ (524 \text{ kHz})$ | 1.91 μs | | | | | | 1 | 1 | $\Phi = f_{\chi}/4 \ (1.05 \ MHz)$ | 0.95 μs | | | | | f. : Main system clock oscillator output frequency CPU operation mode control bits | 0 | 0 | Normal operating mode | |---|---|-----------------------| | 0 | 1 | HALT mode | | 1 | 0 | STOP mode | | 1 | 1 | Undefined | | 1 | 1 | | Figure 5.2-2 Processor Clock Control Register Format #### (2) System clock oscillators The main system clock oscillator uses a crystal oscillator (4.194304 MHz standard) or ceramic oscillator connected to the X1 and X2 pins. An external clock can also be input Fig. 5.2-3 External Circuit to Main System Clock Oscillator Caution: When an external clock is input, the STOP mode cannot be set because the X1 pin is connected to V<sub>SS</sub> in the STOP mode. #### 5.2.3 CPU clock selection The CPU clock is supplied to the $\mu$ PD75402A internal CPU. The reciprocal of the clock becomes the minimum instruction execution time (which is defined to be one machine cycle in the manual). The $\mu$ PD75402A enables to be selected among three steps by setting the PCC. This means that the minimum instruction execution time can be selected among three steps by using a single system clock oscillation frequency $f_{\chi\chi}$ . This function enables CPU operation at high speed (0,95 $\mu$ s at 4.19 MHz) when the supply voltage is 5 V or at low speed (15.3 $\mu$ s at 4.19 MHz) in the backup mode, thereby reducing consumption current and performing operation at low voltage. Fig. 5.2-4 Minimum Instruction Execution Time Change Application Although $\phi$ is changed by using a 4-bit memory handling instruction as described in (1) above, the CPU operates on the old speed before the change during a number of machine cycles which are listed in Table 5.2-1, after the PCC is changed. Since the PCC is cleared when the RES signal is generated, the µPD75402A starts at the minimum speed (where the operation supply voltage range is wide). This enables normal operation although sufficient supply voltage cannot be obtained after power on reset in a slow voltage rise system (to which a high capacitance capacitor is connected). Table 5.2-1 Maximum Time Required for CPU Clock Change | PCC before φ change | PCC after $\phi$ change | Maximum number of machine cycles required for φ change | Maximum time required for φ change (Note) (when f <sub>XX</sub> = 4.19 MHz) | |---------------------|-------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0000 | 0010 | 1 | | | 0000 | 0011 | 1 | | | 0010 | 0000 | 8. | 1000 | | | 0011 | 8 | 16μs | | 0011 | 0000 | 16 | S. Carlotte and C. an | | 0011 | 0010 | 16 | | Note: When the standby mode is not entered until $\phi$ has been changed # 5.3 Clock Output Circuit - (1) Clock output circuit configuration - Fig. 5.3-1 shows a clock output circuit block diagram. - (2) Clock output circuit function The clock output circuit, which outputs clock pulses from the P22/PCL pin, is used to supply clock pulses to remote control output or peripheral LSIs. - Clock pulses are output in the following sequence: - (a) Clock output frequency is selected. Clock output is disabled. - (b) 0 is written into P22 output latch. - (c) Port 2 input/output mode is placed in output mode. - (d) Clock output is enabled. Fig. 5.3-1 Clock Output Circuit Block Diagram Remarks: The circuit is designed so as not to output a spurious short-width pulse when changing between clock output enable and disable. # (3) Clock output mode register (CLOM) CLOM is a 4-bit register to control clock output. CLOM is set by using a 4-bit memory operation instruction. It cannot be read. Example: To output clock $\Phi$ from PCL/P22 pin. MOV A, #1000B MOV CLOM, A CLR1 PORT2.2 MOV XA, #04H MOV PMGA, XA; Set Port2 to Output mode When the RESET signal is generated, CLOM is cleared and clock output is disabled. Caution: Be sure to write 0 into CLOM bit 2. Fig. 5.3-2 Clock Output Mode Register Format Example 1: Output 65.5 kHz (during 4.19 MHz operation) clock from the PCL/P22 pin. (Output clock when the PCL/P22 pin is in the high impedance state.) MOV A, #1011B MOV CLOM, A ; CLOM = 1011B CLR1 PORT2.2 ; P22 ← 0 CLR1 PORT2.2 ; P22 ← 0 MOV XA, #04H MOV PMGB, XA ; PMGB = 00000100B Example 2: Output $\Phi$ (Output clock when the PCL/P22 pin is low.) MOV A, #0 OUT PORT2, A ; $P22 \leftarrow 0$ MOV XA, #04A MOV PMGB, XA MOV A. #1000B MOV CLOM, A ; CLOM ← 1000B # (4) Application example to remote control output The $\mu$ PD75402A clock output function is applicable to remote control output. Remote control output carrier frequency is selected by using the clock frequency selection bit of the clock output mode register. Pulse output is enabled or disabled under software control by using the clock output enable/disable bit. It is designed so that a spurious short-width pulse will not be produced when changing between clock output enable and disable. Fig. 5.3-3 Remote Control Output Application Example # 5.4 Basic Interval Timer The $\mu PD7500X$ contains an 8-bit basic interval timer which has the following functions: - (a) Reference time generation (four types of time interval) - (b) Wait time selection and count when standby mode is released. The basic interval timer can also be applied to a watchdog timer to detect program overrun. #### 5.4.1 Basic interval timer configuration Fig. 5.4-1 shows the configuration of the basic interval timer Remarks: \* denotes instruction executing. Fig. 5.4-1 Basic Interval Timer Configuration # 5.4.2. Basic interval timer mode register (BTM) BTM is a 4-bit register for controlling operation of the basic interval timer. BTM is set by using a 4-bit memory operation instruction. Bit 3 can be set individually by using a bit operation instruction. Example 1: To set the interrupt generation interval to 1.95 ms (4.19 MHz). MOV A, # 1111B MOV BTM. A ; BTM ← 1111B When bit 3 is set to 1, the basic interval timer contents are cleared. At the same time, the basic interval timer interrupt request flag (IRQBT) is also cleared. (The basic interval timer starts.) When the RESET signal is generated, the BTM contents are cleared and interrupt request signal generation is set for the longest interval. Note: Be sure to use a 4-bit write instruction to write 1 into the Caution: Be sure to write 1 into bits 1 and 0 (11). Fig. 5.4-2 Basic Interval Timer Mode Register Format # 5.4.3. Basic interval timer operation The basic interval timer (BT) is always increment when a clock is input from the clock generator. When it overflows, the interrupt request flag (IRQBT) is set. The BT count operation cannot be stopped. The interrupt generation interval can be selected among two types of time by setting the BTM. (See Fig. 5.4-2.) The basic interval timer and interrupt request flag can be cleared by setting BTM bit 3 to 1. (Interval timer start instruction) The basic interval timer (BT) count state can be read by using an 8-bit handling instruction. Data cannot be written into the basic interval timer. Caution: To read the basic interval timer count contents, execute a read instruction twice to prevent reading unstable data during count update. Compare the first and second read contents. If a proper value is obtained, use the second read contents as the read result. If they differ completely, retry from the beginning. Example: Read the BT count contents. MOV HL. #TEMP : Store table address in HL LOOP: MOV XA, BT : First read TEMP, XA ; Save the read value MOV MOV XA. BT : Second read SKE A, @HL : Compare the low-order four bits BR LOOP INCS XCH A. X SKE A. @HL ; Compare the high-order four bits BR LOOP #### 5.4.4 Basic interval timer application examples Example 1: Enable basic interval timer interrupt and set the interrupt generation interval to 1.95 ms (at 4.19 MHz). MOV A, #1111B MOV BTM, A ; Set and start EI ; Enable interrupt EI IEBT : Enable BT interrupt #### Example 2: Watchdog timer application To use the basic interval timer as a watchdog timer, use the basic interval timer interrupt (INTBT) generation function every setup time. First, determine the basic interval timer interrupt generation reference time. Next, divide a program into several modules where processing terminates within the reference time. Clear the counter (BT) and interrupt request flag (IRQBT) at the end of each module. Prepare the program to suppress an interrupt (INTBT) if the program normally operates. That is, if an interrupt occurs, it is decided that the program overruns. ### 5.5 Serial Interface #### 5.5.1 Serial interface configuration The µPD75402A serial interface is a clocked serial interface (CSI). Fig. 5.5.2 shows the serial interface block diagram. #### 5.5.2 Serial interface function The μPD75402A serial interface contains two modes described in (1) and (2) below. The serial clock line SCK and serial data bus line SB0 can cover any desired transfer format because the output level can be handled by using software. #### (1) 3-wire serial I/O mode - 3-wire system of serial clock SCK, serial output SO, and serial input SI. - Clock synchronization 8-bit transfer operation (send and receive at the same time). - Enables connection to any of the μPD7500 series, μCOM-75X family, μCOM-78X family, and peripheral I/O devices. #### (2) SBI (serial bus interface) mode - · Conforms to the NEC serial bus format. - Enables the µPD75402A to communicate with a number of devices by using the two lines of serial clock SCK and serial data bus SB0. - Provides the address, command, and data transfer function and the signal distinction function using the hardware. (See Fig. 5.5-2.) - · Provides the wake-up function for handshaking and the acknowledge and busy signal ouput function. Caution: When the $\mu$ PD75402A operates as a slave CPU, the $\mu$ PD75402A addresses are limited to C0H-C7H. Fig. 5.5-1 SBI System Configuration Example Fig. 5.5.2 Serial Interface Diagram ### Command transfer (from master to slave) Data transfer (from master to slave or slave to master) Fig. 5.5-3 SBI Transfer Timing Chart ### 5.5.3 Main register functions # (1) Serial operating mode register (CSIM) The serial operation mode register (CSIM) consists of eight bits that specify the serial interface operating mode, serial clock, wake-up function, etc. CSIM is set using an 8-bit memory operation instruction. The high-order three bits of CSIM can be set bitwise using the bit name. Bit 6 enables bit test only. Data written into the bit becomes invalid. #### Example 1: To select $f_{\chi}/2^4$ for serial clock, generate a serial interrupt IRQCSI at the end of each serial transfer, and make serial transfer in the SBI mode using the SB0 pin as the serial data bus line. MOV XA, #10001010B MOV C CSIM. XA CSIM 10001010B #### Example 2: To enable serial transfer conforming to the CSIM contents. SET1 CSIE Wake-up function specification bit (WUP): # (a) When WUP=0 IRQCSI is set each time a serial transfer ends. WUP is set to 0 during normal transfer. # (b) When WUP = 1 WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register (SVA) value (wake-up state). When the received address is not its own, an unnecessary interrupt will not be generated. The ACK signal is not output either. The SB0 pin is placed in a high impedance state independent of the SO the latch state. When the RESET signal is generated, all bits are cleared. Fig. 5.5-4 shows the format of the serial operation mode register. | Address | | | | | | | | | Symbol | |---------|------|-----|-----|---|-------|---|-------|---|--------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FE0H | CSIE | COI | WUP | 0 | CSIM3 | 0 | CSIM1 | 0 | CSIM | # Serial clock selection bits (W) | | Serial | | | |-------|------------------------------------|----------|--------------| | CSIM1 | 3-line I/O mode | SBI mode | SCK pin mode | | 0 | SCK pin input | Input | | | 1 | f <sub>x</sub> /2 <sup>4</sup> (26 | Output | | The values enclosed in parentheses are applied when $f_x = 4.19$ MHz. #### Serial interface operating mode selection bits (W) | CSIM3 | Operating mode | Shift register bit order | SO pin function | SI pin function | |-------|------------------------|--------------------------------------------------------|---------------------------------------------------|-------------------| | 0 | 3-line serial I/O mode | SIO <sub>7-0</sub> XA<br>(transfer starts<br>at MBS) | SO/PO2<br>(CMOS output) | SI/PO3<br>(input) | | 1 | SBI mode | SIO <sub>7-0</sub> ★ XA<br>(transfer starts<br>at MSB) | SB0/PO2<br>(N-channel open drain<br>input/output) | PO3 input | # Wake-up function specification bit (W) | | 0 | IRQCSI is set each time a serial transfer ends in each mode. | |-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WUP | 1 | WUP is set to 1 only during the SBI mode. IRQCSI is set only when the address received after the bus is released matches the slave address register data (wake-up state). SB0 is placed in the high impedance state | # Coincidence signal received from address comparator (R (bit test is only enabled)) Note 1, Note 2 | | COI | 0 | Slave address register and shift register data mismatch. | |---|-----|---|----------------------------------------------------------| | ١ | 001 | 1 | Slave address register and shift register data match. | # Serial interface operation enable/disable specification bit (W) | | | Shift register operation | Serial clock counter | IRQCSI flag | SO/SB0 and SI/SB1 pins | |------|---|------------------------------|----------------------|-------------|------------------------------------------------------| | | 0 | Shift operation is disabled. | Clear | Hold | Port 0 function only | | CSIE | 1 | Shift operation is enabled. | Count operation | Can be set. | Also used for port 0 according to each mode function | Fig. 5.5-4 Serial Operation Mode Register Format # Notes: - 1. COI is only valid before serial transfer starts or after it is complete. An undefined value is read during serial transfer. - 2. Data written into COI is ignored. - 3. Be sure to write 0 into CSIM bits 4, 2, and 0. Remarks: (W): Data write is only enabled. (R): Data read is only enabled. # (2) Serial bus interface control register (SBIC) The 8-bit serial bus interface control register (SBIC) consists of the serial bus state control bits and flags indicating the states of input data from serial bus. It is mainly used in the SBI mode. Fig. 5.5–5 shows the SBIC format. SBIC is set or tested by using a bit operation (manipulation) instruction. When the RESET signal is generated, all the SBIC bits are cleared. #### Cautions: - 1. SBIC cannot be set by using 4- or 8-bit memory operation instruction. - In the 3-line serial I/O mode, use only the following two bits for SO latch control:(a) Bus release trigger bit (RELT): To set SO latch - (b) Command trigger bit (CMDT): To clear SO latch - 3. For the bus release, command, acknowledge, and busy signals, see 5.5.5 (3). Example 1: To output command signal. SET1 CMDT Example 2: To test RELD and CMDD and determine the receive data type for appropriate processing. SKF RELD ; RELD test BR !ADRS SKT CMDD ; CMDD test BR !DATA CMD: ; Command transfer DATA: ; Data transfer ADRS: : Address transfer | Addre | ss | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Symbol | |-------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------|------------------------------|-----------------------------|----------------| | FE2 | ⊵н Г | BSYE | ACKD | ACKE | ACKT | CMDD | RELD | CMDT | RELT | SBIC | | Bus release | ــ<br>triggei | bit (W) | <u> </u> | | | | | | | | | RELT | | atch is set | | ting the bit. | It is used to | o output bus | release sig | gnal. After S | O latch is s | et, the bit is | | Command | trigger t | oit (W) | | | | | | | | | | CMDT | | | ared by set | | It is used to | o output a c | ommand si | gnal. After S | SO latch is c | leared, the | | Bus release | detect | ion flag (F | R) | | | | | | | | | RELD | _ | lear condi<br>RELD=0) | tion | | When the match the | e transfer st<br>e address re<br>e slave addr<br>e RESET sig | eceived after<br>ress registe | r the bus is<br>r (SVA) data | released do<br>a. | oes not | | | Setting condition When the address received after the bus is released matches the (RELD=1) slave address register data. (Wake up) | | | | | | nes the | | | | | Command | detectio | n flag (R) | | | | | | | | | | CMDD | Clear condition<br>(CMDD=0) | | | <ol> <li>When the transfer start is indicated.</li> <li>When the <u>bus rel</u>ease signal is detected.</li> <li>When the RESET signal is input.</li> </ol> | | | | | | | | | Setting condition<br>(CMDD=1) | | | When the command signal is detected. | | | | | | | | Acknowled | ge trigg | er bit (W) | | | | | | | | | | ACKT | | d only afte | r transfer | | | e signal is o<br>fter execution | | | period of So | <del>C</del> K | | | T is aut | T, set ACk | (E to 0. | er acknowle | edge signal | is output. | 2. ACK | T cannot be | cleared usi | ng software. | | | 0 | | | | dge signal output is disabled (the signal can be output by setting the bit ACKT). | | | | | | | ACKE | | | Before trai | | | | | | ne ninth cloc<br>ng ACKE to | | | AONE | 1 | | After trans | | Acknowledge signal is output during one clock period of SCK immediately after execution of the set instruction (automatically output by presetting ACKE to 1). | | | | | | # Acknowledge detection flag (R) | ACKD | Clear condition<br>(ACKD=0) | When the <u>transfer</u> is started. When the RESET is input. | | |------|--------------------------------|-------------------------------------------------------------------|--| | ACKD | Setting conditions<br>(ACKD=1) | When the acknowledge signal is detected. | | # Synchronous busy enable bit (R/W) | BSYE | 0 | Synchronous busy signal output is disabled. Synchronous busy signal output is stopped in synchronization with the SCK falling edge immediately after execution of the clear instruction. | |------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | 1 | Synchronous busy signal is output on the SCK falling edge following an acknowledge signal. | # Remarks: (R): Read is only enabled. (W): Write is only enabled. (R/W): Both read and write are enabled. Fig. 5.5-5 SBIC Format Figure 5.5-6 RELT, CMDT, RELD, CMDD Operation Set after transfer completion Fig. 5.5-7 ACKT Operation Fig. 5.5-8 ACKE Operation # (3) Slave address register (SVA) The slave address register (SVA) is an 8-bit register to set the slave address of the $\mu$ PD75402A when the $\mu$ PD75402A is connected to the serial bus as a slave device in the SBI mode. Since the high-order five bits of SVA are fixed to 11000 on hardware, the $\mu PD75402A$ assignment addresses are limited to C0H - C7H. The SVA value is compared with the received 8-bit data by the address comparator. If a match is found between them, serial operation mode register (CSIM) bit 6 (COI) is set to 1. If no match is found when the address is received, the bus release detection flag (RELD) is cleared. When WUP is set to 1, IRQCSI is set to 1 only when a match is found (wakeup detection). This interrupt request informs the $\mu$ PD75402A that a communication request is sent by master to the $\mu$ PD75402A. The SVA is handled by using an 8-bit memory handling instruction. It can only be written. When the RESET signal is generated not during the standby mode, the SVA value becomes undefined. Caution: Be sure to write data in the range of C0H to C7H into the SVA. # 5.5.4 Signals in SBI mode Table 5.5-1 and 5.5-2 list the signals used in the SBI mode. Table 5.5-1 Signals in SBI Mode (I) | Signal name | Output<br>device | Definition | Timing chart | Output<br>condition | Flag<br>influence | Explaination | |----------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | Bus release<br>signal<br>(REL) | Master | SB0 rising edge<br>when SCK = 1 | (Figure 1) | RELT is set. | • RELD is set. • CMDD is cleared. | The signal is followed<br>by CMD signal output<br>indicating that the<br>send data is an address | | Command<br>signal<br>(CMD) | Master | SB0 falling<br>edge when SCK = 1 | (Figure 2) | CMDT is set. | • CMDD is set. | i) After REL signal is<br>output, send data<br>is an address.<br>ii) When REL signal is<br>not output, send<br>data is a command. | | Acknowledge<br>sign <u>al</u><br>(ACK) | Master/<br>Slave | Low signal output to SB0 during one clock period of SCK after completion of serial reception | (Figure 3) | 1 ACKE = 1<br>2 ACKT is<br>set. | • ACKD is set. | Completion of reception | | Bus <u>y sign</u> al<br>(BUSY) | Slave | (Synchronous busy<br>signal)<br>Low signal output to<br>SB0 following<br>acknowledge signal | | • BSYE = 1 | <del>-</del> | Serial reception cannot<br>be done because<br>processing is being<br>performed. | | | | (Asynchronous busy signal) Low signal output to SB0 (except during serial transfer). It is not synchronized with SCK. | | CMDT is set. | - | | | Ready signal<br>(READY) | Slave | High signal output to<br>SB0 before<br>start or after completion<br>of serial transfer | - | 1 BSYE = 0<br>2 Execution<br>of SIO data<br>write instruc-<br>tion (transfer<br>start indication) | <u>-</u> | Serial reception can be done. | Table5.6-2 Signals in SBI Mode (II) | Signal name | Output<br>device | Definition | Timing chart | Output<br>condition | Flag<br>influence | Explanation | |--------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------| | Se <u>rial clo</u> ck<br>(SCK) | Master | Synchronous clock to output address, | (Figure 4) | Execution of<br>SIO data write<br>instruction<br>when CSIE =1<br>(serial transfer<br>start<br>indication)<br>(Note 2) | IRQCSI is<br>set (on the<br>rising edge<br>of ninth<br>clock).<br>(Note 1) | Signal output timing<br>to serial data bus | | Address<br>(A7-0) | Master | 8-bit data transferred<br>in synchronization<br>with SCK after REL<br>and CMD signals are<br>output. | (Figure 5) | | (Note 1) | Slave device address<br>value on serial bus | | Command<br>(C7-0) | Master | 8-bit data transferred in synchronization with SCK after CMD signal only is output (REL signal is not output). | (Figure 6) | | None | Indication message<br>sent to slave device | | Data<br>(D7–0) | Master<br>or<br>Slave | 8-bit data transferred<br>in synchronization<br>with SCK when neither<br>REL nor CMD signal<br>is output. | (Figure 7) | | None | Numeric data<br>processed by slave<br>or master device | Notes: 1. When WUP = 0, IRQCSI is always set on the ninth clock SCK rising edge. When <u>WUP</u> = 1, IRQCSI is set only when the received address matches the value in the slave address register (SVA). 2. In the BUSY state, transfer is started after the READY state is set. #### 5.5.5 Serial interface operation The serial interface operates in any of the following three modes: - · Operation stop mode - · 3-wire serial I/O mode - SBI mode Table 5.5-3 Serial Interace Operation Mode | CSIE | сѕімз | Operation mode | | | | | | |------|-------|------------------------|--|--|--|--|--| | 0 | - | Operation stop mode | | | | | | | 1 | 0 | 3-wire serial I/O mode | | | | | | | 1 | 1 | SBI mode | | | | | | ## (1) Operation stop mode When CSIE = 0, the serial interface is placed in the operation stop mode. In this mode, serial transfer is not made. The operation stop mode is selected to reduce power consumption when the serial interface is not used. In the mode, the shift register does not perform shift operation and can be used as a normal 8-bit register. When CSIM1, CSIM0 = 00 (SCK = external clock), the P01/SCK pin is placed in high impedance; when CSIM1, CSIM0 are not set to 00 (SCK = internal clock), the P01/SCK pin outputs high level. The P02/SO/SB0 and P03/SI pins are placed in high impedance and used only for the input port function. When RESET is input, the operation stop mode is selected. To select the mode during serial transfer, previously disable a serial interrupt. After selecting the mode, clear the interrupt request flag (IRQCSI). #### (2) 3-line serial I/O mode The 3-line serial I/O mode is compatible with the mode used by the $\mu$ PD7500 series or other $\mu$ COM-75X family devices. Fig. 5.5-11 shows the 3-line serial I/O mode operation timing. Serial transfer start is indicated by executing an instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. Fig. 5.5-11 3-line Serial I/O Mode Timing In this mode, shift register shift operation is performed in synchronization with the serial clock ( $\overline{SCK}$ ) falling edge, and send data is held in the <u>SO</u> latch and output from the SO pin. The receive data input to the SI pin is latched in the shift register on the rising edge of $\overline{SCK}$ . Since the SO pin is used as a CMOS output and outputs the SO latch state, the SO pin output state can be handled by setting the RELT and CMDT bits. However, do not try to change it during serial transfer. A serial clock can be selected from among four clocks, as listed in Table 5.5-4, by setting the mode register. Normally, shift operation is started by: - 1) Setting the operating mode and serial clock selection data in the mode register (CSIM) - 2) Setting transfer data in the shift register (SIO) (serial operation is started by executing the SIO data write instruction) Serial transfer automatically stops at the end of 8-bit transfer, and the interrupt request flag (IRQCSI) is set. Table 5.5-4 Serial Clock Selection and Application | Mode register | | Serial clock | Timing at which shift register read/write or | Application | | |---------------|---------------------------------|------------------------|-------------------------------------------------------|---------------------------------|--| | CSIM1 | Source | Serial clock mask | serial transfer start is enabled | Application | | | 0 | External SCK | masked when 8-bit data | Only when serial transfer stops (Note) or SCK is high | Slave CPU | | | 1 | f <sub>xx</sub> /2 <sup>4</sup> | transfer terminates | Only when serial transfer stops (Note) or SCK is high | Medium speed<br>serial transfer | | Note: The clause "when serial transfer stops" means the operation stop mode or serial clock mask state after 8-bit data transfer. The shift register is read or written by using an 8-bit transfer instruction. Example: Transfer RAM data specified in the HL register pair to SIO. At the same time, read SIO data into a given accumulator and start serial transfer. MOV XA, @HL ; Read send data from RAM XCH XA, SIO ; Exchange send data and receive data and start transfer. Fig. 5.5-12 #### (3) SBI mode The SBI mode enables the µPD75402A to communicate with a number of devices by using the SCK and SB0 lines. Figs. 5.5-13 to 5.5-15 show the timing of operations according to the type of data to be transferred. In the SBI mode, indication of serial transfer start is also given by executing the instruction to write data into the shift register (SIO), MOV or XCH. Be sure to give a start indication when CSIE = 1. Shift register shifting is made in synchronization with the serial clock (SCK) falling edge, and send data is held in the SO latch and output from the SB0/P02 pin starting at MSB. Receive data input to the SB0 pin is latched in the shift register on the rising edge of SCK. The SB0 pin specified for the serial data bus is used as N-channel open drain input/output and needs pull-up. When data is received, the N-channel transistor must be turned off. By writing FFH into SIO and shifting it, the N-channel transistor can always be turned off during transfer. When the wake-up function specification bit (WUP) is set to 1, however, the N-channel transistor is always turned off, and FFH need not be written into SIO before reception. Fig. 5.5-13 SBI Mode Timing (Address Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.5-14 SBI Mode Timing (Command Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. Fig. 5.5-15 SBI Mode Timing (Data Transfer) Note 1: Where SIO's data is read out by MOV instruction, then BSYE flag is cleared. Note 2: Where SIO's data is exchanged (read/write) by XCH instruction. #### 5.5.6 Error detection Since the serial bus SB0 during sending is also read into the sending device shift register (SIO) in the SBI mode, a send error can be detected by comparing the SIO data before the sending starts with that after the sending terminates. In this case, if the two data pieces differ from each other, it is decided that a send error occurred. # 5.5.7 Serial interface application The serial interface for each mode is explained using examples of applications. The normal serial interface communication sequence is as follows: - 1) Set transfer mode. (Set data in CSIM.) - 2) Write data into SIO and give transfer start indication. (MOV SIO, XA or XCH XA, SIO. At that time, automatic transfer start indication is given.) - 3) After checking that the serial interrupt routine or interrupt request flag (IRQCSI) is set, read receive data, and start transfer. - The SBI mode communication sequence is explained in detail in (3) below. - (1) 3-line serial I/O mode - (a) To transfer data starting at MBS using transfer clock of 262 kHz (at 4.19 MHz) (master operation). Example: MOV XA, #10000010B MOV CSIM, XA ; Transfer mode is set. MOV XA, TDATA ; TDATA is the transfer data storage address. MOV SIO, XA ; Transfer data is set. : Transfer is started. #### Caution: At the second time or after, transfer can be started by setting data in SIO (MOV SIO, XA or XCH XA, SIO). In this application example, the µPD75402 SI pin can be used for input. (b) To transfer data starting at the MSB using external clock (slave operation). Example: Main routine MOV XA, #80H MOV CSIM. XA : Serial operation stop, external clock MOV XA, TDATA MOV SIO, XA ; Transfer data is set. ; Transfer is started. EI IECSI ΕI Interrupt routine (MBE = 0) MOV XA. TDATA MOV XA, TDATA XCH XA, SIO ; Receive data - send data, transfer start MOV RDATA, XA ; Receive data is saved. RETI #### (2) SBI mode An application example of serial data communication in the SBI mode is given. In the example, the $\mu PD75402A$ can operates as a slave CPU. Althogh the master can also be changed by using a command, the µPD75402A can not serve as a master CPU. # (a) Serial bus configuration The serial bus configuration in the application example given here assumes that the µPD75402A is connected to bus lines as one device in the serial bus. The following two μPD75402A pins are used: Serial data bus SB0 (P02/SO) and serial clock SCK (P01). Fig. 5.5-16 shows an example of a serial bus configuration. Fig. 5.5-16 Serial Bus Configuration Example # (b) Command explanation Command types The application example uses the following commands: - 1) READ: - Data is transferred from slave to master. - 2) WRITE: - Data is transferred from master to slave. - WRITE command completion is reported to slave. - 4) STOP: - - WRITE command stop is reported to slave. - 5) STATUS: - The slave state is read. - 6) RESET: - The current slave being selected is made unselected. - 7) CHGMST: The master authorization is transferred to the slave #### Communication sequence The communication sequence between the master and slave is as follows: - Communication is started by the master, which sends the address of the slave to communicate with and selects the slave (chip select). - The slave which receives the address returns $\overline{ACK}$ and communicates with the master. (The slave is placed in selected state.) - 2) Command and data are transferred between the slave selected in 1) and the master. Since command and data are transferred point-to-point (between the master and specific slave), other slaves must be desplacted. - 3) Communication terminates when the slave is deselected in either of the following cases: - When the master sends the RESET command, the selected slave is deselected. - If the master is changed by using the CHGMST command, the device changed from master to slave is deselected. Command format The command transfer formats are shown below: #### 1) READ command The READ command reads data from a given slave. The read data count ranges from one to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave Fig. 5.5-17 READ Command Transfer Format After receiving the data count, the slave returns $\overline{ACK}$ if the number of $\underline{data}$ bytes that can be sent is greater than the data count. If it is less than the data count, the slave does not return $\overline{ACK}$ , resulting in an error. During data transfer, the slave compares the SIO contents before and after data transfer to check that data has been output to the bus normally. If the SIO contents before and after transfer do not match, the slave does not return ACK, resulting in an error. 2) WRITE, END, and STOP commands The WRITE, END, and STOP commands are used to write data into a particulary slave. The write data count ranges from 1 to 256 bytes. The master specifies the data count in a parameter. If 00H is specified for the data count, 256-byte data transfer is assumed to be specified. - M: Output by master - S: Output by slave # Fig. 5.5-18 WRITE, END Command Transfer Format After receiving the data count, the slave returns $\overline{ACK}$ if the receive data store area is larger than the data count. If it is less than the data count, it does not return $\overline{ACK}$ , resulting in an error. At the termination of all data transfer, the master sends the END command to the slave. It signals that all data has been transferred normally. The slave also receives an END command before it completes all data reception. In this case, the data which has been received immediately before the END command is received becomes valid. During data sending, the master compares the SIO contents before and after data sending to check that data has been output to the bus normally. If the SO contents before and after sending do not match, the master sends the STOP command and stops data transfer. - M: Output by master - S: Output by slave Fig. 5.5-19 STOP Command Transfer Format When receiving the STOP command, the slave invalidates the 1-byte data received immediately before receiving the STOP command. 3) STATUS command The STATUS Command Transfer Format - M: Output by master - S: Output by slave Fig. 5.5-20 STATUS Command Status Format Fig. 5.5-21 shows the format of the status returned by the slave. Fig. 5.5-21 STATUS Command Status Format To send status data, the slave compares the contents before and after sending status data. If they do not match, the slave does not return ACK, resulting in an error. # 4) RESET command The RESET command is used to cause the currently selected slave to be selected. When the RESET command is issued, all slaves can be deselected. - M: Output by master - S: Output ba slave Fig. 5.5-22 RESET Command Transfer Format #### 5) CHGMST command The CHGMST command transfers the master authorization to the currently selected slave. - M: Output by master - S: Output by slave Fig. 5.5-23 CHGMST Command Transfer Format When receiving the CHGMST command, the slave decides whether or not it can receive the master authorization, and returns either of the following data to the master: - OFFH: Master change is enabled. - 00H : Master change is disabled. When transferring data, the slave compares the SIO contents before and after data transfer. If they do not match, the slave does not return $\overline{ACK}$ , resulting in an error. If no error occurs, the master serves as a slave after 0FFH data sending is complete. If no error occurs, the slave serves as the master after 0FFH data sending is completed. # Error occurrence When a communication error occurs, the master and slave operate as explained below: The slave informs the master of error occurrence by returning no ACK. When an error occurs, the status bit (bit 2) indicating error occurence is set to 1 and all command processing being performed is cancelled.\_\_\_\_ After completing the sending or receiving of one byte, the master checks whether or not $\overline{ACK}$ is returned from slave. If $\overline{ACK}$ is not returned from slave within a given period after sending or receiving is completed, the master decides that an error has occurred and outputs a dummy $\overline{ACK}$ signal. Fig. 5.5-24 Master and Slave Operation when Error Occured The following errors are possible: - Errors that may occur in the slave - 1) Command transfer format is erroneous. - 2) Undefined command is received. - 3) The number of data bytes to be transferred (data count) is insufficient during READ command execution. - 4) Data storage area is insufficient during WRITE command execution. - 5) When READ, STATUS, or CHGMST command data is sent, data changes. When any error in 1) or 5) occurs, no ACK is returned. - Errors that may occur in the master When WRITE command data is sent, if data changes, STOP command is sent to the slave. # 6. INTERRUPT FUNCTION The μPD75402A contains three vectored interrupt sources and one testable inputs for versatile application. The $\mu$ PD75402A interrupt control circuit has the following features to enable very high-speed interrupt service: - (a) Whether or not interrupts can be acknowledged can be controlled by using enable flag (IEXXX) and interrupt master enable flag (IME). - (b) The interrupt service start address during interrupt service can be set as desired by using a vector table. Starting the actual interrupt service program is fast. - (c) Interrupt request flag (IRQXXX) can be tested and cleared. Interrupt occurrence can be checked by using software. - (d) The standby mode (HALT) can be released by making an interrupt request (except for INT0). # 6.1 Interrupt Control Circuit Configuration Fig. 6.1-1 shows configuration of the interrupt control circuit. The hardware devices are mapped in data memory. Fig. 6.1-1 Interrupt Control Circuit Block Diagram #### 6.2 Interrupt Sources and Vector Table Table 6.2-1 lists the μPD75402A interrupt sources. Figure 6.2-1 shows the μPD75402A interrupt vector table. **Table 6.2-1 Interrupt Request Sources** | Interrupt request occurrence source | Internal/<br>external | Interrupt<br>priority (Note) | Vectored interrupt request signa (vector table address) | | | |------------------------------------------------------------------|-----------------------|------------------------------------------|---------------------------------------------------------|--|--| | INTBT (reference time interval signal from basic interval timer) | Internal | 1 . | VRQ1 (0002H) | | | | INT0 (INT0 pin input specification edge detection) | External | 2 | VRQ2 (0004H) | | | | INTCSI (serial data transfer termination signal) | Internal | 3 | VRQ3 (0008H) | | | | INT2<br>(INT2 pin input rising edge detection) | External | Testable input signal (IRQ2 flag is set) | | | | Note: The interrupt priority is the priority assigned to the interrupt request source when a number of interrupt requests occur. #### Address Fig. 6.2-1 Interrupt Vector Table The interrupt priority in Table 6.2-1 indicates the interrupt execution priority when a number of interrupt requests occur at the same time or are held. The interrupt service start addresses are written into the vector table. The vector address table is set by using an assembler pseudo instruction (VENTn). Example: Set INTBT vector table. GOTOBT VENT1 Symbol indicating the interrupt service Vector table at address 0002 routine start address Caution: The vecto table address specified in VENTn (n = 1; 2; 4) becomes address 2n. Example: Set INTBT and INT0 vector table. GOTOBT VENT1 VENT2 GOTO0 # 6.3 Interrupt Control Circuit Hardware ## (1) Interrupt request flags and interrupt enable flags The interrupt request flag (IRQXXX) is set to 1 when an interrupt request occurs; it is automatically cleared when a given interrupt service is executed. The interrupt enable flag (IEXXX) is provided for each interrupt request flag separately. When it contains 1, its corresponding interrupt is enabled; when 0, disabled. When an interrupt request flag is set to 1 and its corresponding interrupt enable flag is set to 1, a vectored interrupt request (VRQn) occurs. This signal except VRQ2 is also used to release the standby mode (HALT mode). The interrupt request and enable flags are handled by using bit handling and 4-bit memory handling instructions. The interrupt enable flag is handled by using EI IEXXX and DI IEXXX instructions. Normally, the interrupt request flag is tested by using the SKTCLR instruction. Example: EI IEO ; Enable INTO DI IEBT ; Disable INTBT SKTCR IRQCSI ; Skip and clear if IRQCSI is set to 1 If the interrupt request flag is set to 1 by using an instruction, a vectored interrupt is executed as if it occurred although it does not occur. When the RESET signal is generated, the interrupt request and enable flags are cleared and all interrupts are disabled. Table 6.3-1 Interrupt Request Flags and Interrupt Enable Flags | Interrupt request flag | Interrupt request flag set signal | Interrupt<br>enable flag | |------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------| | IRQBT | Reference time interval signal from basic interval timer | IEBT | | IRQ0 | INTO/P10 pin input signal edge detection. The detection edge is selected by using the INT0 mode register (IM0) | IE0 | | IRQCSI | Serial interface serial data transfer operation termination signal | IECSI | | IRQ2 | INT2/P12 pin input signal rising edge detection | IE2 | #### (2) External interrupt input pin hardware Fig. 6.3-1 shows the INTO and INT2 configuration. Fig. 6.3-1 INTO and INT2 Configuration The INTO pin is external interrupt input where noise can be eliminated by using sampling clocks and the detection edge can be selected. The INTO noise eliminator detects level change by using two sampling clocks. Thus, a pulse narrower than the sampling clock width is removed as a noise and a pulse wider than twice the sampling clock width is securely acknowledge as an interrupt signal. (See Fig. 6.3-2.) Either of the clocks can be selected for the sampling clock. Fig. 6.3-2 INTO Noise Eliminator Input/Output Timing The INT0 input detection edge and sampling clock are selected by using the edge detection mode register (IM0). When the INT0 pin is used for the port pin function, data is also input through the noise eliminator. Input data with sufficient width so as not to remove the data as a noise. The INT2 pin is external testable input where testable flag is set when the rising edge is detected. It does not have a noise eliminator using sampling clocks, but contains the function of eliminating a narrow pulse by using analog delay. As with INTO, input suffeciently wide signals. (See Fig. 6.3-3.) Fig. 6.3-3 INT2 Input Noise Elimination Fig. 6.3-4 shows the format of the edge detection mode register (IM0) to select the detection edge. The IM0 is set by using a 4-bit memory handling instruction. When the RESET signal is generated, all the IM0 bits are cleared and the rising edge is selected for INT0 and INT2 input detection edges. Caution: If the edge detection mode register is changed, the interrupt request flag may be set. Disable interrupts beforehand, and change the mode register. Clear the interrupt request flag by using the CLR1 instruction before enabling interrupts. If f<sub>x</sub>/64 is selected for the sampling clock in an IM0 change, clear the interrupt request flag within 16 machine cycles after the mode register is changed. Fig. 6.3-4 Edge Detection Mode Register Format (3) Interrupt master enable flag (IME) Interrupt master enable flag enables or disables acknowledgement of all interrupts. IME is set to 1 or to 0 by using the EI and DI instructions. When the RESET signal is generated, IME is cleared, disabling acknowledgement of all interrupts. # Address Fig. 6.3-5 IME Format ## (4) Interrupt status flag The interrupt status flag (IST0) indicates the current status of processing being performed by CPU; it is contained in the PSW. The interrupt control circuit controls multi-interrupts (as listed in Table 6.3-2) according to the contents of interrupt status flag. IST0 can not be changed by using a 4-bit or a one-bit manipulation instruction. IST0 is always set to 1 during interrupt serving. Therefore, it is not possible to write 0 to IST0 in the interrupt service routine which would result in multiple interrupt. When an interrupt is acknowledged, IST0 is saved in stack memory together with other PSW bits, then it is automatically set to 1. When the RETI instruction is executed, the former IST0 value (0) is restored. When the RESET signal is generated, the flag is cleared. # Table 6.3-2 IST0 and Interrupt Service State | IST0 | Status of processing CPU processing contents | | Interrupt requests that can be acknowledged | After interrupt is acknowledged | | | |------|----------------------------------------------|----------------------------------|---------------------------------------------|---------------------------------|--|--| | | | | | IST0 | | | | 0 | Status 0 | During normal program processing | All interrupts can be acknowledged. | 1 | | | | 1 | Status 1 | During interrupt service | None of the interrupts can be acknowledged. | - | | | # 6.4 Interrupt Sequence When an interrupt occurs, it is processed as shown in Fig. 6.4-1. Fig. 6.4-1 Interrupt Service Flow ## 6.5 Machine Cycles Until Interrupt Service Starts (1) When an interrupt request occurs in the interrupt enable state When an interrupt request for which its corresponding interrupt enable flag is set to 1 occurs (the interrupt request flag is set to 1) in the EI state (IME = 1), the number of machine cycles required until execution of a given interrupt service routine program starts is as follows: (a) When interrupt request flag (IRQXXX) is set during execution of an address FBxH (interrupt hardware) handling instruction Address FBxH handling instruction IRQXXX is set during this period (depending on the number of the machine cycles for the instruction) One to three machine cycles (depending on the number of machine cycles for the instruction) Three machine cycles (required for interrupt service) Interrupt routine execution (required for interrupt service) As shown above, interrupt routine service starts in a maximum of six machine cycles after the data memory address FBxH handling instructions are given, interrupt routine service starts in a maximum of six machine cycles after the last handling instruction terminates. (b) When interrupt request flag is set during execution of an instruction other than in (a) (one to three machine cycles depending on the number of the machine of cycles of the instruction) In this case, a maximum of six machine cycles are required. (2) When interrupt is enabled after an interrupt request occurs When an interrupt request occurs (interrupt request flag is set to 1) in the interrupt disable state, the number of machine cycles required until interrupt is enabled is as follows: (The interrupt disable state is set when the interrupt master enable flag (IME) is cleared or the interrupt enable flag (IEXXX) corresponding to the generated interrupt request is cleared.) - (a) When interrupt enable flag is set to 1 after IME is set to 1 (EI state) by EI instruction execution In this case, the number of machine cycles varies depending on the number of the machine cycles of the instruction following the IEXXX set instruction (EI IEXXX). - When a 1-machine-cycle instruction follows the IEXXX set instruction, interrupt routine service is started after one more instruction is executed. When a 2- or 3-machine-cycle instruction follows the IEXXX set instruction, interrupt routine service is started after that instruction is executed. As shown above, interrupt routine service is started in a maximum of seven machine cycles if the IEXXX set instruction is followed by a 1-machine-cycle instruction; otherwise, interrupt routine service is started in a maximum of six machine cycles. (b) When IME is set to 1 (El state) by El instruction execution after interrupt enable flag is set to 1. In this case, a maximum of six machine cycles are required. #### 6.6 Interrupt Application To use the interrupt function, first - ① Set the interrupt enable flags of the interrupts to be used to 1 by using EI IEXXX instructions; - @ To use INTO, select the active edge by setting IMO; - 3 Set the interrupt master enable flag (IME) to 1 by using El instruction in the main program. - To return from a given interrupt service program, use the RETI instruction. #### (1) Interrupt enable and disable - ① When the RESET signal is generated, all interrupts are disabled. - ② Interrupt enable flags are set to 1 by executing the El IEXXX instructions. In this step, all interrupts remain disabled. - The interrupt master enable flag is set to 1 by executing the EI instruction. In this step, INTO and INTCSI are enabled. - Interrupt enable flag is cleared by executing the DI IEXXX instruction. INT0 is disabled. - All interrupts are disabled by executing the DI instruction. (2) Usage example of INTBT, INTO (falling edge active), and INTCSI. Multi-interrupt is not done. - $\ \, \textcircled{1}$ All interrupts are disabled by the $\overline{\mbox{RESET}}$ signal and status 0 is set. - Falling edge active is selected for INTO. - ③ Interrupts are enabled by the EI and EI IEXXX instructions. - On the INTO falling edge, the INTO interrupt service program is started. The status is changed to status 1 and all interrupts are disabled. - A return is made from the interrupt service program by the RETI instruction. The status is restored to status 0 and interrupts are enabled. (3) Pending interrupt execution - interrupt input during interrupt disable - ① If INT0 is set during interrupt disable, the request flag is held. ② When interrupts are enabled by the EI instruction, the INT0 service program is started. <sup>3</sup> Simular to 1 above. When INTCSI is held enabled, the INTCSI service program is started. # (4) Pending interrupt execution - ① If INTO and INTCSI are occured at the same time during execution of a single instruction, INTO, which is higher in priority than INTCSI, is executed first; INTCSI is held. - When a return is made from the INTO service program by the RETI instruction, the held INTCSI service program is started. #### 7. STANDBY FUNCTION To make the most of the CMOS process features, low consumption current, the µPD75402A enables CPU operation to be stopped in the standby mode for very low CPU consumption current. The μPD75402A standby mode is the STOP or HALT mode which can be selected according to the application. The STOP mode stops the system clock oscillator. In this mode, almost all CPU consumption current is leakage current only. Data memory can also be retained at low supply voltage (up to $V_{DD} = 2 V$ ). Thus, it is useful to retain the data memory contents at very low consumption current. The $\mu$ PD75402A STOP mode is not released when an interrupt request is made. It can be released only when RESET is input. The HALT mode continues system clock oscillator oscillation, but stops CPU clock of supply. Thus, CPU operation stops. Although the HALT mode cannot reduce consumption current as compared with the STOP mode, it is useful to restart processing immediately when an interrupt request is made or for intermittent operation. In either the STOP or HALT mode, all the contents of the registers, flags, and data memory immediately before the standby mode is selected are retained. The output latch state and output buffer state of the input/output ports are also retained. The input/output port state is previously set so that the entire system consumption current is minimized. Caution: Although efficient low consumption current, low voltage operation can be performed by using the standby mode and CPU clock change function, the time as described in 5.2.3 is required from new clock selection using the PCC register to operation start with the new selected clock. Thus, to use the clock change function and the standby mode in combination, select the standby mode in the time required for the change. #### 7.1 Standby Mode Setting and Operation State Table 7.1-1 Operating State in Standby Mode | | | Stop mode | HALT mode | | |--------------------------|----------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--| | Mode setting instruction | | STOP instruction | HALT instruction | | | Operation state | Clock oscillator | Clock oscillation stop | Stop of only CPU clock (oscillation is continued) | | | | Basic interval timer | Operation stop | Operation (IRQBT is set to 1 at reference time intervals.) | | | | Serial interface | Operation is enabled only when external SCK input is selected for the system clock. But INTCSI is not enabled | Can operate. | | | | Clock output circuit | Operation stop | Only CPU clock cannot be output | | | | External interrupts | INT2 operation is not enabled. INT0 operation is not enabled. | INT2 operation is enabled INT0 operation is not enabled | | | | CPU | Operation | on stop | | | Release signal | | RESET input | RESET input or interrupt request flag<br>from interrupt request flag set to 1<br>whose corresponding interrupt enable<br>flag is set to 1 | | To select the STOP mode, use the STOP instruction to set PCC bit 3 to 1. To select the HALT mode, use the HALT instruction to set PCC bit 2 to 1. Be sure to enter a NOP instruction following the STOP or HALT instruction. When the CPU operation clock is changed by using the low-order two bits of the PCC, time lag may occur from PCC rewriting to CPU clock change. To change the operation clock before the standby mode and the CPU clock after the standby mode is released, select the standby mode in machine cycles required to change the CPU clock after the PCC is rewritten. The standby mode retains data in data memory and all registers which stop operation during the standby mode, such as general purpose registers, flag, mode registers, and output latches. Caution 1: When the STOP mode is selected, the X1 pin is connected internally to V<sub>SS</sub> (GND potential) to suppress clock oscillator leakage. Do not use the STOP mode in a system which uses an external clock. Caution 2: The µPD75402A and the evaluation chip installed on the evaluation board differ in STOP mode release operation when an interrupt request is made as follows: μPD75402A STOP mode is not released when an interrupt request is made. · Evaluation chip : STOP mode is released when an interrupt request is made. To eliminate this difference, disable all interrupt requests before selecting the STOP mode. Caution 3: Since interrupt request signal is used to release the HALT mode, if there is an interrupt source with both interrupt request and enable flags set to 1, the HALT mode is released immediately when the mode is entered. #### 7.2 Standby Mode Release The STOP mode is released only when RESET is input. The HALT mode is released when RESET is input or by the standby release signal generated when the interrupt request flag whose corresponding interrupt enable flag is set to 1. Fig. 7.2-1 shows standby mode release operation. Caution: When the standby mode (STOP or HALT) is released when RESET is input, the µPD75402A does not insert wait before starting instruction execution. Instruction execution is started immediately when reset is released. (1) STOP mode release when RESET is input When the high-to-low transition of RESET input is made, the oscillator starts oscillation at the same time the reset state is entered. When the low-to high transition of RESET input is made, instruction execution is started although oscillation operation does not become stable. Thus, take sufficient low level width of RESET input and reserve the oscillation stable time. When the reset state is released, a branch is made to the reset start address. Unlike the normal reset operation, the data memory retains the contents before the STOP mode is selected. (2) HALT mode release when RESET is input When the high-to-low transition of RESET input is made, the HALT mode is released and the reset state is entered. When the low-to-high transition of RESET input is made, a branch is made to the reset start address and instruction execution is started. Unlike the normal reset operation, the data memory retains the contents before the HALT mode is selected. (3) HALT mode release when an interrupt occurs When the interrupt request flag whose corresponding interrupt enable flag is set to 1, the standby release signal is generated and the HALT mode is released. However, when an INTO interrupt request is made, the standby release signal is not generated. (a) STOP mode release when RESET is input (b) HALT mode release when RESET is input HALT instruction RESET signal Operating mode HALT mode Operating mode Oscillation Fig. 7.2-1 Standby Mode Release Operation Remarks: Broken line: When the interrupt request releasing the HALT mode is acknowledged (IME = 1). Fig. 7.2-1 Standby Mode Release Operation cont'd #### 7.3 Operation after Standby Mode is Released - (1) If the standby mode (STOP or HALT) is released when RESET is input, the normal reset operation is performed. - (2) If the standby mode (HALT) is released when an interrupt request occurs, whether or not a vectored interrupt is to be made when the CPU restarts instruction execution, is determined by the interrupt master enable flag (IME) contents. - (a) When IME = 0 - After the HALT mode released, execution is restarted at the instruction (NOP) following the HALT mode set instruction. The interrupt request flag is retained. - (b) When IME = 1 - After the HALT mode is released, two instructions following th HALT mode set instruction are executed, then the vectored interrupt is executed. However, if the HALT mode is released when INT2 (testable input) occurs, no vectored interrupt occurs; processing as in (a) above is performed. #### 7.4 Standby Mode Application To use the standby mode, perform the following sequence: - Detect standby mode selection sources such as power off when interrupt input or port input is made. - 2 Set input/output ports so as to minimize consumption current. - Specify standby mode release interrupts. (However, in the HALT mode, interrupt enable flags not to release the HALT mode are cleared.) - Specify operation after the standby mode is released. (Set the IME according to whether or not interrupt service is made after the HALT mode is released). - Select the CPU clock after the standby mode is released. To change the CPU clock, select the standby mode in machine cycles required for the CPU clock change after the PCC is rewritten.) - Select the standby mode by using the STOP or HALT instruction. #### 8. RESET FUNCTION When a low level is input to the RESET input pin, the system is reset and the hardware is placed in the state as listed in Table 8.1. When the low-to-high transition of RESET input is made, the reset state is released. The contents of reset vector table address 001H are loaded into the program counter (PC) bits 7-0 and the contents of the low-order three bits of address 000H are loaded into PC bits 10-8, then a branch is made. Program execution is started at the branch destination address. The enabled reset starts at any desired address. Initialize the contents of the registers as required in a program. The RESET input pin is Schmitt trigger input having hysteresis characteristic at the threshold level. It also contains the eliminating function of noise narrower than the analog delay width to prevent noise from causing malfunction. (See Fig. 8-1.) Fig. 8-1 Reset Signal Acknowledge Fig. 8-2 Reset when Power is Turned On Table 8-1 Hardware State after Reset | | Hardware | RESET input during standby mode | RESET input during operation | | | |-------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--|--| | Program counter ( | PC) | The low-order three bits of program memory address 000H are loaded into PC10-PC8 and the address 001H contents are loaded into PC7-PC0. | Same as left | | | | PSW | Carry flag (CY) | Held | Undefined | | | | | Skip flag (SK0-SK2) | 0 | 0 | | | | : | Interrupt status flag (IST0) | 0 | 0 | | | | Stack pointer (SP) | Undefined | Undefined | Undefined | | | | Data memory (RA | M) | Held (Note) | Undefined | | | | General purpose r | egisters (X, A, H and L) | Held | Undefined | | | | Basic interval | Counter (BT) | Undefined | Undefined | | | | timer | Mode register (BTM) | 0 | 0 | | | | Serial interface | Shift register (SIO) | Held | Undefined | | | | | Operation mode register (CSIM) | 0 | 0 | | | | | SBI control register (SBIC) | 0 | 0 | | | | | Slave address register (SVA) | Held | Undefined | | | | Clock generator, clock output | Processor clock control register (PCC) | 0 | 0 | | | | circuit | Clock output mode register (CLOM) | 0 | 0 | | | | Interrupt function | Interrupt request flag (IRQXXX) | Cleared | Cleared | | | | | Interrupt enable flag<br>(IEXXX) | 0 | 0 | | | | | Interrupt master enable flag (IME) | 0 | 0 | | | | | INT0 mode registers (IM0) | 0 | 0 | | | | Digital ports | Output buffers | Off | Off | | | | | Output latches | Cleared | Cleared | | | | | Input/output mode registers (PMGA and PMGB) | 0 | 0 | | | | | Pull-up resistor specification register (POGA) | 0 | 0 | | | | Pin state | P00-P03, P10, P12,<br>P20-P23, P30-P33,<br>P60-P63, | Input | Same as left | | | | | P50-P53 | When internal pull-up resistor is specified: High level During open drain: High impedance | Same as left | | | Note: When RESET is input, the contents of data memory addresses 038H-03DH become undefined. # 9. ELECTRICAL CHARACTERISTICS # Absolute Maximum Ratings (Ta = 25 °C) | Item | Symbol | Conditions | | Ratings | Unit | | | |-----------------------|------------------|----------------------------------------------------------|-------------------|--------------------------------------|------------------------------|------|--| | Supply voltage | V <sub>DD</sub> | | | | -0.3 to +7.0 | ٧ | | | Input voltage | V <sub>I1</sub> | Other than port 5 | Other than port 5 | | | V | | | | V <sub>I2</sub> | Ports 5 | With built-in | pull-up resistor | -0.3 to V <sub>DD</sub> +0.3 | V | | | | | | Open drain | | -0.3 to +11 | ٧ | | | Output voltage | v <sub>o</sub> | | | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | High level | I <sub>OH</sub> | Single pin | | -15 | mA | | | | output current | | All pins | | | -30 | ] "" | | | Low level | I <sub>OL</sub> | One port pin of ports 0, 3, 5 | | Peak value | 30 | | | | output current | Note | and 6 | | | 15 | | | | | | Port 2 single pin Total of ports 0, 3 and 5, except P33 | | Peak value | 20 | mA | | | | - | | | Effective value | 10 | | | | | | | | otal of ports 0, 3 and 5, Peak value | | IIIA | | | | | | | Effective value | 60 | | | | | | Total of parts 2.6 | and Dag | Peak value | 100 | | | | | | Total of ports 2, 6 and P33 | | Effective value | 60 | | | | Operation Temperature | T <sub>opt</sub> | | | | -40 to +85 | °C | | | Storage Temperature | T <sub>stg</sub> | | | | -65 to +150 | °C | | Note: Use the following formula to calculate the effective value. (Effective value) = (Peak value) $\times \sqrt{\text{duty}}$ # Characteristics of Main System Clock Oscillator (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------|------|------|------| | Ceramic | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 2.0 | | 5.0 | MHz | | resonator | C1十 | Note 1 Oscillation frequency (f <sub>XX</sub> ) Note 2 Oscillation stabilization time Note 1 Oscillation frequency (f <sub>XX</sub> ) After V <sub>DD</sub> reaches the minimum value in the oscillator voltage range Note 1 Oscillation frequency (f <sub>XX</sub> ) Note 2 Oscillation frequency (f <sub>XX</sub> ) Note 2 Oscillation frequency (f <sub>XX</sub> ) Note 2 Oscillation stabilization time V <sub>DD</sub> =4.5 to 6.0V 10 m: Note 1 X1 input frequency (f <sub>X</sub> ) Note 1 X1 input frequency (f <sub>X</sub> ) Substitute of the condition of the properties of the minimum value in the oscillator voltage range 2.0 4.19 5.0 MH Discrepance of the condition of the properties of the properties of the condition of the properties of the condition of the properties of the condition of the properties of the properties of the condition of the properties proper | ms | | | | | | Crystal | X1 | Oscillation frequency | | 2.0 | 4.19 | 5.0 | MHz | | resonator | | Note 1 Oscillation frequency (f <sub>xx</sub> ) Note 2 Oscillation time Note 1 Oscillation time Note 1 Oscillation time Note 1 Oscillation frequency (f <sub>xx</sub> ) Note 2 Oscillation frequency (f <sub>xx</sub> ) Note 1 Oscillation frequency (f <sub>xx</sub> ) Note 2 Oscillation stabilization time V <sub>DD</sub> =4.5 to 6.0V 10 10 11 12 14 15 16 17 17 18 18 18 18 18 18 18 18 | V <sub>DD</sub> =4.5 to 6.0V | | | 10 | ms | | | OD. | | ms | | | | | | External clock | X1 X2<br>μPD74HCU04 | X1 input frequency | | 2.0 | : | 5.0 | MHz | | External clock | | X1 input high/low level width (t <sub>XH</sub> , t <sub>XL</sub> ) | | 100 | | 500 | ns | Note 1: The oscillation frequency and X1 input frequency are indicated only to express the characteristics of the oscillator. Refer to the AC characteristics for instruction execution time. Note 2: The oscillation stabilization time is the time required for the oscillator to stabillate after V<sub>DD</sub> is applied or after the STOP mode is released. # **Recommended Ceramic Resonator** | Manufacturer | Part name* | Francisco (Mile) | Capacita | ance [pF] | Oscillation voltage range [V] | | | |--------------------------|-------------|------------------|----------|-----------|-------------------------------|------|--| | | Fait name | Frequency [MHz] | C1 | C2 | MIN. | MAX. | | | Murata Mfg.<br>Co., Ltd. | CSAxxxMG093 | 2.00-2.44 | 30 | 30 | 2.7 | 6.0 | | | | CSAxxxMGU | 2.45-4.91 | 30 | 30 | 2.7 | 6.0 | | | | KBR-2.0MS | 2.0 | 47 | 47 | 3.0 | 6.0 | | | Kyocera Corp. | KBR-4.19MS | 4.19 | 33 | 33 | 3.0 | 6.0 | | | | KBR-5.0MS | 5.0 | 33 | 33 | 3.3 | 6.0 | | <sup>\*</sup> xxx indicates frequency. # DC Characteristics (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Item | Symbol | | Conditions | MIN. | TYP. | MAX. | Unit | |----------------------------------|------------------------|-------------------------------------------|------------------------------------------------------------|----------------------|------|--------------------|----------| | High level input | V <sub>IH1</sub> | Ports 2 and 3 and | 6 | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | voltage | V <sub>IH2</sub> | Ports 0, 1 and RES | SET pin | 0.8V <sub>DD</sub> | | Y <sub>DD</sub> | V | | | V <sub>IH3</sub> | Port 5 | With built-in pullup resistor | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | V | | | | | Open drain | 0.7V <sub>DD</sub> | | 10 | ٧ | | | V <sub>IH4</sub> | X1, X2 | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | V | | Low level input | V <sub>IL1</sub> | Ports 2, 3, 5, 6 | | 0 | | 0.3V <sub>DD</sub> | V | | voltage | V <sub>IL2</sub> | Ports 0, 1 and RES | SET pin | 0 | | 0.2V <sub>DD</sub> | ٧ | | | V <sub>IL3</sub> | X1, X2 | | 0 | | 0.4 | <b>V</b> | | High level output voltage | V <sub>OH1</sub> | Ports 0, 2, 3, 5, 6 | $V_{DD} = 4.5 \text{ to } 6.0V$<br>$I_{OH} = -1 \text{mA}$ | V <sub>DD</sub> -1.0 | | | ٧ | | | | | $I_{OH} = -100 \mu A$ | V <sub>DD</sub> -0.5 | | | ٧ | | Built-in pull-up resistor | R <sub>L1</sub> | Ports 0, 1, 2, 3, 6, | $V_{DD} = 5.0V \pm 10\%$ | 15 | 40 | 80 | kΩ | | resistor | V <sub>IN</sub> = 0V | (Except P00, P10)<br>V <sub>IN</sub> = 0V | V <sub>DD</sub> = 3.0V ± 10% | 30 | | 300 | kΩ | | | R <sub>L2</sub> Port 5 | V <sub>DD</sub> = 5.0V ± 10% | 15 | 40 | 70 | kΩ | | | | | $V_{OUT} = V_{DD} - 2.0V$ | V <sub>DD</sub> = 3.0V ± 10% | 10 | | 60 | kΩ | | Low level output voltage | V <sub>OL1</sub> | Ports 3, 5, 6 | V <sub>DD</sub> = 4.5-6.0V<br>I <sub>OL</sub> = 15mA | | 0.6 | 2.0 | ٧ | | | | Ports 0, 2, 3, 5, 6 | V <sub>DD</sub> = 4.5-6.0V I <sub>OL</sub> = 1.6mA | | | 0.4 | ٧ | | | | | I <sub>OL</sub> = 400μA | | | 0.5 | ٧ | | | V <sub>OL2</sub> | SB0 open drain | Pull-up resistance: $1k\Omega$ min. $V_{DD} = 4.5-6.0V$ | | | 0.2V <sub>DD</sub> | ٧ | | High level input | I <sub>LIH1</sub> | V <sub>IN</sub> = V <sub>DD</sub> | Other than indicated below | | | 3 | μΑ | | leakage current | I <sub>LIH2</sub> | | X1, X2 | | | 20 | μА | | | I <sub>LIH3</sub> | V <sub>IN</sub> = 10V | Port 5 (with open drain) | | | 20 | μΑ | | Low level input | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V | Other than indicated below | | | -3 | μΑ | | leakage current | I <sub>LIL2</sub> | | X1, X2 | | | -20 | μА | | High level output | I <sub>LOH1</sub> | V <sub>OUT</sub> = V <sub>DD</sub> | Other than indicated below | | | 3 | μА | | leakage current | I <sub>LOH2</sub> | V <sub>OUT</sub> = 10V | Port 5 (with open drain) | | | 20 | μА | | Low level output leakage current | I <sub>LOL</sub> | V <sub>OUT</sub> = 0V | | | | -3 | μА | # DC Characteristics (cont'd) (Ta = -40 to +85 °C, $V_{DD}$ = 2.7 to 6.0V) | Item | Symbol | Conditions | | | MIN. | TYP. | MAX. | Unit | | |-------------------------|------------------|-------------------------------------------------|-------------------------------------|---------------------|-----------|------|------|------|----| | Supply current (Note 1) | I <sub>DD1</sub> | 4.19 MHz crystal<br>oscillation<br>- C1=C2=22pF | V <sub>DD</sub> = 5V ± 10% (Note 2) | | | 2.5 | 8 | mA | | | I <sub>DD</sub> | | | V <sub>DD</sub> = 3V ± 10% (Note 3) | | | 0.5 | 1.5 | mA | | | | 1., | | Mode | V <sub>DD</sub> = 5 | V ± 10% | | 500 | 1500 | μΑ | | | DD2 | | | V <sub>DD</sub> = 3 | V ± 10% | | 150 | 450 | μΑ | | | | STOP mode | V <sub>DD</sub> = 5' | V ± 10% | | | 0.5 | 20 | μА | | | 'DD3 | DD3 | V <sub>DD</sub> = 3' | V ± 10% | | | 0.1 | 10 | μΑ | | | | | | | Ta = 25°C | | 0.1 | 5 | μА | Note 1: The current of the built-in pull-up resistor is not included. Note 2: When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. Note 3: When operated in the low-speed mode with the PCC set to 0000. # AC Characteristics (Ta = -40 to 85 C, VDD = 2.7 to 6.0V) | Item | Symbol | Condition | | MIN. | TYP. | MAX | Unit | |----------------------------------------------------------------|---------------------|----------------------------------|-----------------------------|--------|------|-----|------| | (Note 1) Cycle time<br>(minimum instruction<br>execution time) | t <sub>CY</sub> | Operation with main system clock | V <sub>DD</sub> = 4.5 –6.0V | 0.95 | | 32 | μs | | | | | | 3.8 | | 32 | μs | | Interrupt input high/low | t <sub>INTH</sub> , | INT0 | | Note 2 | | | μs | | lever width | t <sub>INTL</sub> | INT2 | | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | | 10 | | | μs | Note 1: The cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure below shows the $V_{DD}$ vs cycle time $(t_{CV})$ when operated with the main system clock. Note 2: 2t<sub>CY</sub> or 64/f<sub>x</sub>, depending on the setting of the interrupt mode register (IM0). Capacitance (Ta = 25 °C, V<sub>DD</sub> = 0V) | | טט יי טט | | | | | | |--------------------------|------------------|-----------------------|------|------|------|------| | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | | Input capacitance | C <sub>IN</sub> | f = 1 MHz | | | 15 | pF | | Output capacitance | C <sub>OUT</sub> | Unmeasured pin turned | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | to be 0V. | | | 15 | pF | | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------------------------|------------------------|------|------|------| | SCK cycle time | t <sub>KCY1</sub> | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | | | | 3800 | | | ns | | SCK high/low level | t <sub>KL1</sub> | V <sub>DD</sub> = 4.5 -6.0V | 1 <sub>KCY1</sub> -50 | | | ns | | width | t <sub>KH1</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SI set-up time<br>(against SCK ) | t <sub>SIK1</sub> | | 150 | | | ns | | SI hold time<br>(against SCK ) | t <sub>KSI1</sub> | | 400 | | | ns | | SCK | t <sub>KSO1</sub> | V <sub>DD</sub> = 4.5 -6.0V | | | 250 | ns | | | | | | | 1000 | ns | 3line serial I/O mode (SCK ... External clock input) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-------------------|-----------------------------|------|------|------|------| | 001/ | | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | SCK cycle time | t <sub>KCY2</sub> | | 3200 | | | ns | | SCK high/low level width | t <sub>KL2</sub> | V <sub>DD</sub> = 4.5 -6.0V | 400 | | | ns | | | t <sub>KH2</sub> | | 1600 | | | ns | | SI set-up time (against SCK ) | t <sub>SIK2</sub> | | 100 | | | ns | | SI hold time<br>(against SCK ) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK<br>SO output delay<br>time | | V <sub>DD</sub> = 4.5 -6.0V | - | | 300 | ns | | | t <sub>KSO2</sub> | | | | 1000 | ns | Note: The output delay time (for rising edge) of the serial line must be shorter than 600 ns. For example, if SB0 is pulled up with 5K ohms, the total capacitance of the serial bus line must be no greater than 120 pF. SBI mode (SCK ... Internal clock output (master)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------------------|-------------------|-----------------------------|------------------------|------|------|------| | SCK cycle time | t <sub>KCY3</sub> | V <sub>DD</sub> = 4.5 -6.0V | 1600 | | | ns | | SCR Cycle time | | | 3800 | | | ns | | SCK high/low level | t <sub>KL3</sub> | V <sub>DD</sub> = 4.5 -6.0V | t <sub>KCY1</sub> -50 | | | ns | | width | t <sub>KH3</sub> | | t <sub>KCY1</sub> -150 | | | ns | | SB0 set- <u>up ti</u> me<br>(against SCK † ) | t <sub>sıкз</sub> | | 150 | | | ns | | SB0 hold time<br>(against SCK ) | t <sub>KSI3</sub> | | 1 <sub>KCY1</sub> 2 | | | ns | | SCK | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 250 | ns | | time | t <sub>KSO3</sub> | | 0 | | 1000 | ns | | SCK → SB0 ↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SBO - SCK | t <sub>sвк</sub> | | t <sub>KCY</sub> | | | ns | | SB0 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | | ns | SBI mode (SCK ... External clock input (slave)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-----------------------------------|-------------------|-----------------------------|---------------------|------|------|------| | COK and a time | | V <sub>DD</sub> = 4.5 -6.0V | 800 | | | ns | | SCK cycle time | t <sub>KCY4</sub> | | 3200 | | | ns | | SCK high/low level | t <sub>KL4</sub> | $V_{DD} = 4.5 - 6.0 V$ | 400 | | | ns | | width | t <sub>KH4</sub> | | 1600 | | - | ns | | SB0 set-up time<br>(against SCK ) | t <sub>SIK4</sub> | | 100 | | | ns | | SB0 hold time<br>(against SCK ) | t <sub>KSI4</sub> | | t <sub>KCY1</sub> 2 | | | ns | | SCK - | | V <sub>DD</sub> = 4.5 -6.0V | 0 | | 300 | ns | | SB0 output delay time | t <sub>KSO4</sub> | | 0 | | 1000 | ns | | SCK → SB0 ↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0 ↓→ SCK↓ | t <sub>sbk</sub> | | t <sub>KCY</sub> | | | ns | | SB0 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0 high level width | t <sub>SBH</sub> | | t <sub>KCY</sub> | | | ns | # AC Timing Measurement Points (Except X1 input) Serial Transfer Timing 3-line serial I/O mode # **Serial Transfer Timing** Bus release signal transfer: Interrupt input timing RESET input timing ### Data Memory STOP Mode Low Voltage Data Retention Characteristic (Ta = -40 to +85 °C) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|---------------------------------|------|------|------|------| | Data retention voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention current (Note1) | I <sub>DDDR</sub> | V <sub>DDR</sub> = 2.0V | | 0.1 | 10 | μΑ | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | O!! -4!4-b:!!4!4! (N-4-0) | | Release by RESET input (Note 3) | | | 4 | ms | | Oscillation stabilization time (Note 2) | tosc | Release by RESET input (Note 4) | | | 10 | ms | Note 1: Current in the internal pull-up resistors is not included. Note 2: The oscillation stabilization time is the time required before beginning CPU operation in order to prevent unstable CPU operation when oscillation is initiated. Note 3: After $V_{DD}$ reaches the oscillation voltage range, if ceramic resonator is used. Note 4: After $V_{DD}$ reaches the oscillation voltage range, if crystal oscillator is used. Data Retention Timing (when STOP mode is released by RESET input) ### 9.1 Package Dimension Package Dimension of 28-pin Plastic DIP (600 mil) (Unit: mm) P28C-100-600A1 P28C-70-400A Package Dimension of 44-pin Plastic QFP (Units: mm) P44GB-80-3B4 Package Dimension of ES 44-pin Ceramic QFP (Reference Drawing) (Unit: mm) Note 1: A metal cap is connected to pin 17 and is $V_{SS}$ (GND) level. Note 2: Lead wire length is not stipulated because cutting process of lead ends is out of production control. # 10. $\mu$ PD75P402 LOW END 4-BIT MICROCOMPUTER ### 10.1 Overview The $\mu$ PD75PD402 is a QTOP<sup>TM</sup> microcomputer provided by replacing $\mu$ PD75402A internal mask ROM with one-time PROM. The $\mu$ PD75P402 into which the user can write programs is suitable for evaluation during system development or small quantity production. $\mu$ PD75P402 should not be used for final EMI or latch up tests. To see this document, also refer to the $\mu$ PD75402A document. ### Features: • µPD75402A compatible • Internal one-time PROM: 1920 x 8 bits • PROM programming characteristics: μPD27C256A compatible. PROM can be written with general purpose PROM writer. • Single power supply 5 V $\pm$ 10% ### Order Information | Order name | Package | |--------------------------------|-------------------------------------------------| | μPD75P402C | 28-pin plastic DIP | | μPD75P402CT<br>μPD75P402GB-3B4 | 28-pin plastic shrink DIP<br>44-pin plastic QFP | #### 10.2 Pin Connections 28-Pin Plastic DIP (1) Normal operation mode P00-P03 : Port 0 P10, P12 : Port 1 P20-P23 : Port 2 P30-P33 : Port 3 P50-P53 : Port 5 P60-P63 : Port 6 SCK : Serial clock input/output SO/SB0 : Serial input/output SI : Serial input PCL : Clock output INTO : INT2 : External test input X1, X2 : Main system clock RESET : Reset input V\_DD : Power supply SS : Ground V<sub>PP</sub> : Setting the GND from external ( $^{\star}$ ): used by only $\mu$ PD75P402. In operating mode, set to GND from external To share printed circuit board with $\mu$ PD75P402 in the $\mu$ PD75402A, set the $V_{pp}$ pin to the GND potential. (2) PROM program mode A0-A14 : Address input O0-O7 : Data input/output CE : Chip enable input OE : Output enable input V<sub>DD</sub> : Power supply V<sub>PP</sub> : Program power supply V<sub>SS</sub> : Ground (\*): used by μPD75402 only. In operating mode, set to GND from external. Also to share pcb with μPD75402A (where this pin is NC), set pin to GND potential. Top view 44-pin plastic QFP (bent lead) ## (1) Normal operation mode (\*): Used by only $\mu$ PD75P402. To share printed circuit board with $\mu$ PD75P402 in the $\mu$ PD75402, set the NC pin which is applicable to the V<sub>PP</sub> in the $\mu$ PD75402, to GND potential. (2) PROM mode Top view ## 10.3 Block Diagram II-6-103 ### 10.4 Pin Function List Table 4.1-1 Port Pins | Pin name | 1/0 | Also used for (Note) | Function | | | | |----------|-----|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | P00 | 1 | (A7) | 4-bit input port (Port 0). Internal pull-up resistor can be specified for P01-P03 in | | | | | P01 | I/O | SCK (A6) | 3-bit units on software. | | | | | P02 | 1/0 | SO/SB0 (A5) | | | | | | P03 | ı | SI (A4) | | | | | | P10 | 1 | INT0 (A9) | 2-bit input port (port 1). P10 contains a sampling clock noise eliminator. | | | | | P12 | | INT2 (A8) | P12 contains an analog delay noise eliminator. Internal pull-up resistor can be specified for P12 on software | | | | | P20 | I/O | (CE) | 4-bit input/output port (port 2). Input or output mode can be specified in 4-bit | | | | | P21 | | (A10) | units. Internal pull-up resistor can be specified 4-bit units on software. | | | | | P22 | | PCL (OE) | | | | | | P23 | | (A11) | | | | | | P30-P33 | I/O | (00-03) | Programmable 4-bit input/output port (port 3). Input or output mode can be specified bitwise. Internal pull-up resistor can be specified in 4-bit units on software. LED can be directly driven. | | | | | P50-P53 | I/O | (A3-A0) | 4-bit N-ch open drain input/output (port 5). Input or output mode can be specified in 4-bit units. LED can be directly driven. | | | | | P60-P63 | I/O | (04-07) | 4-bit input/output port (port 6). Input or output mode can be specified in 4-bit units. Internal pull-up resistor can be specified in 4-bit units on software. LED can be directly driven. | | | | Remarks: The μPD75P402 does not enable 8-bit input/output because the ports are not paired. Note: The pins enclosed in parentheses are used in the PROM programming mode. Table 10.4-2 Pin Other Than Ports (in Normal Operation Mode) | Pin name | 1/0 | Also used for (Note) | Function | | | | |-----------------|----------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | INT0 | I | P10 (A9) | Edge-detected vectored interrupt request input pin (detection edge can be selected by using the mode register). Sampling clock noise elimination function is contained. | | | | | INT2 | ı | P12 (A8) | Edge detection external test input pin (rising edge detection). Analog delay noise eliminator is contained. | | | | | SI | ı | P03 (A4) | Serial data input pin. | | | | | SO | 1/0 | P02/SB0 (A5) | Serial data output pin. | | | | | SCK | 1/0 | P01 (A6) | Serial clock input/output pin. | | | | | SB0 | 1/0 | P02/SO (A5) | Serial bus input/output pin. | | | | | PCL | 1/0 | P22 (OE) | Clock output pin. | | | | | X1 | | (A14) | System clock oscillation crystal or ceramic oscillator connection pins. To supply | | | | | X2 | | (A13) | clock from the external, input the clock to X1 and its reverse phase to X2. | | | | | RESET | ı | (A12) | System reset input pin. Analog delay noise eliminator is contained. | | | | | V <sub>DD</sub> | <u> </u> | _ | Positive power supply pin. | | | | | V <sub>SS</sub> | _ | | GND potential pin. | | | | | V <sub>PP</sub> | _ | | Program voltage apply pin in the PROM programming mode. In normal operation mode, connect the pin to ${\sf V}_{\sf SS}$ . | | | | Note: The pins enclosed in parantheses are used in the PROM programming mode. Table 10.4-3 Pin Other Than Ports (in PROM Programming Mode) | Pin name | 1/0 | Also used for (Note) | Function | |-----------------|-----|----------------------|----------------------------------------------------------------------------------------------------| | A0-A3 | ı | P53-P50 | Address input pins. | | A4-A7 | ı | P03-P00 | | | A8 | ı | P12 | | | A9 | ı | P10 | | | A10 | ı | P21 | | | A11 | 1 | P23 | | | A12 | 1 | RESET | | | A13 | 1 | X2 | | | A14 | ı | X1 | | | O0-O3 | I/O | P30-P33 | Data input/output pins. | | 04-07 | I/O | P60-P63 | | | CE | | P20 | Chip enable signal input pin. | | ŌĒ | Ī | P22 | Output enable signal input pin. | | V <sub>PP</sub> | | | Program voltage apply pin. Connect the pin to $\mathbf{V}_{\mathrm{SS}}$ in normal operation mode. | ### 10.4.1 Pins Input/Output Circuits The $\mu PD75P402$ pin input/output circuits are shown schematically below. Table 10.4-4 Pin Input/Output Circuit Types | Tubic 10.4 4 1 in input output circuit 1 ypco | | | | | | | | |-----------------------------------------------|-------------|---------------|----------|--|--|--|--| | Pin | I/O type | Pin | I/Otype | | | | | | P00 | B | P20, P21, P23 | E-B | | | | | | P01/SCK | F)-A | P22/PCL | <u> </u> | | | | | | P02/SO/SB0 | <b>Б</b> -в | P30-P33 | E–B | | | | | | P03/SI | <b>B</b> -c | P50-P53 | M–B | | | | | | P10/INT0 | B | P60-P63 | E-B | | | | | | P12/INT2 | <b>B</b> -c | RESET | B | | | | | Remarks: OSchmitt trigger input Pin I/O configurations Following figures show the internal circuit configurations at the I/O ports. ## (1) Type A (part of Type E-B) This is a CMOS standard input buffer. (2) Type B This is a Schmitt trigger input with hysteresis characteristics. (3) Type B-C This is a Schmitt trigger input with hysteresis characteristics. (4) Type D (Part of Type E-B, F-A) This is a push-pull output that can be set to high impedance (with both P-ch and N-ch off). (5) Type E-B (6) Type F-A (7) Type F-B II-6-107 ### (8) Type M-B ### 10.5 Differences Between μPD75P402 and μPD75402A The $\mu$ PD75P402 is a product provided by replacing $\mu$ PD75402A internal mask ROM with one-time PROM. Table 10.5-1 lists the differences between the products, Refer to the µPD75402A documents for detailed information on the CPU function and internal hardware. Table 10.5-1 Differences Between µPD75P402 and µPD75402A | lt. | em | μPD75P402 | μPD75402A | | | |--------------------------------|--------------|---------------------------------------------------------|-------------|--|--| | Program memory | | One-time PROM Mask ROM | | | | | | | • 000H-77FH<br>• 1.920 x 8 bits | | | | | Pull-up resistor | Ports 0-3, 6 | Can be specified on software. | | | | | Port 5 | | None | Mask option | | | | Operation supply voltage range | | 5V ± 10% 2.7 V to 6.0 V | | | | | Pin connection | | They differ in V <sub>pp</sub> pin and multiplexed pins | | | | ### 10.6 One-Time PROM Programming The $\mu$ PD75P402 internal program memory is one-time PROM (1920 x 8 bits) that can be written electrically. To write programs into the one-time PROM, set the PROM mode and use the pins listed in Table 10.6-1. The $\mu$ PD75P402 programming characteristics are compatible with the $\mu$ PD27C256A. Table 10.6-1 Pin Functions During One-Time PROM Programming | Pine name | Function | | | | | |-----------------|------------------------------------------------------------------|--|--|--|--| | V <sub>PP</sub> | One-time PROM programming voltage input | | | | | | A0-A14 (Note) | Address input | | | | | | O0-O7 | Data input (during write) or data output (during verify or read) | | | | | | CE | Chip enable input | | | | | | ŌĒ | Output enable input | | | | | | V <sub>DD</sub> | Supply voltage input | | | | | Note: A11-A14 are dummy pins provided to make the same pin assignments as the μPD27C256A. Input a low level to the A11-A14 pins. ### 10.7 One-Time PROM Programming Operation Mode When +6 V is applied to the $V_{DD}$ pin and +12.5 V to the $V_{PP}$ pin, the $\mu$ PD75P402 is placed in the program write/verify mode. The mode is placed in the operation mode listed in Table 10.7-1 according to how the CE and $\overline{OE}$ pins are set. The one-time PROM contents can be read by setting the $\mu$ PD75P402 to the read mode. Table 10.7-1 One-Time PROM Programming Operation Mode | Pin | CE | ŌĒ | V <sub>PP</sub> | V <sub>DD</sub> | 00-07 | |-----------------|----|-----|-----------------|-----------------|----------------| | Program write | L | Н | | | Data input | | Program verify | Н | L | +12.5 V | +6 V | Data output | | Program inhibit | Н | Н | | | High impedance | | Read | L | L | | | Data output | | Output disable | L | Н | +5 V | +5 V | High impedance | | Standby | Η | L/H | | | High impedance | Caution: When $V_{PP}$ is set to +12.5 V and $V_{DD}$ is set to +6 V, setting both $\overline{CE}$ and $\overline{OE}$ low is inhibited. ### One-Time PROM Write Procedure Data is written into one-time PROM at high speed as described below: - (1) Supply +6 V to $V_{DD}$ and +12.5 V to $V_{PP}$ . - (2) Supply initial address. - (3) Supply write data. - (4) Supply a 1-ms program pulse (active low) to the CE pin. - (5) Enter the program inhibit mode. - (6) Enter the verify mode. If the data is not written normally, proceed to (7). If it is not written normally, repeat (3) to (6). If the data cannot be written after 25 repetitions, regard the one-time PROM as a defective device and stop write operation. - (7) Supply write data. Supply X (number of (3) (6) repetitions) x 3 ms program pulses (additional write). - (8) Enter the program inhibit mode. - (9) Increment the address - (10) Repeat (3) (9) until the last address is reached. - (11) Enter the read mode. Verify all byte data. If the byte is not written normally, regard the one-time PROM as a defective device. - (12) Turn off the power. One-Time PROM Write/Verify Timing ## **One-Time PROM Read Procedure** The one-time PROM contents can be read onto external data bus O0-O7 as described below: - (1) Supply 5 V to the $V_{DD}$ and $V_{PP}$ pins. - (2) Input the address of the data to be read to the A0-A14 pins. - (3) Enter the read mode. - (4) Output the data to the O0-O7 pins. .... ## 11. ELECTRICAL CHARACTERISTICS ## Absolute Maximum Ratings (Ta = 25 °C) | Item | Symbol | Conditions Ratings | | Unit | | | | |-----------------------|------------------|-------------------------------------|-----------------------------|-----------------|------------------------------|------------|--| | Supply voltage | V <sub>DD</sub> | | | | -0.3 to +7.0 | ٧ | | | Input voltage | V <sub>11</sub> | Other than port | Other than port 5 | | | V | | | | V <sub>I2</sub> | Ports 5 | Ports 5 Open drain | | -0.3 to +11 | ٧ | | | Output voltage | V <sub>o</sub> | | | | -0.3 to V <sub>DD</sub> +0.3 | ٧ | | | High level | Гон | Single pin | | | -15 | _ | | | output current | | All pins | | | -30 | mA | | | Low level | l <sub>OL</sub> | One port pin of ports 0, 3, 5 and 6 | | Peak value | 30 | | | | output current | Note | | | Effective value | 15 | | | | | | Port 2 single pin | | Peak value | 20 | | | | | | | Transfer pin | | 10 | | | | | | Total of ports 0, | 3 and 5, | Peak value | 100 | m <b>A</b> | | | | | except P33 | | Effective value | 60 | IIIA | | | | | | | Peak value | 100 | | | | | | Total of ports 2, | Total of ports 2, 6 and P33 | | 60 | 1 | | | Operation Temperature | T <sub>opt</sub> | | | - | -10 to +70 | °C | | | Storage Temperature | T <sub>stg</sub> | | | | -65 to +150 | °C | | Note: Use the following formula to calculate the effective value. (Effective value) = (Peak value) $\times \sqrt{\text{duty}}$ # Characteristics of Main System Clock Oscillator (Ta = -10 to +70 °C, $V_{DD}$ = $5V \pm to$ 10%) | Oscillator | Recommended constants | Item | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------|---------------------------------------------|---------------------------------------------------------------------------------|-----------|------|------|------|------| | Coromio | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 2.0 | | 5.0 | MHz | | Ceramic resonator C1 C1 C2 | Note 2<br>Oscillation<br>stabilization time | After V <sub>DD</sub> reaches the minimum value in the oscillator voltage range | | | 4 | ms | | | [X1 X2]<br>□ □ □ | X1 X2 | Note 1<br>Oscillation frequency<br>(f <sub>XX</sub> ) | | 2.0 | 4.19 | 5.0 | MHz | | Crystal<br>resonator | C1 ± | Note 2<br>Oscillation<br>stabilization time | | | | 10 | ms | | External clock | X1 X2 | Note 1<br>X1 input frequency<br>(f <sub>X</sub> ) | | 2.0 | | 5.0 | MHz | | External Clock | PD74HCU04 | X1 input high/low level width (t <sub>XH</sub> , t <sub>XL</sub> ) | | 100 | | 500 | ns | Note 1: The oscillation frequency and X1 input frequency are indicated only to express the characteristics of the oscillator. Refer to the AC characteristics for instruction execution time. Note 2: The oscillation stabilization time is the time required for the oscillator to stabillate after V<sub>DD</sub> is applied or after the STOP mode is released. ### **Recommended Ceramic Resonator** | Manufacture | D | Fraguenay (MILIN) | Capacitance [pF] | | | |---------------|-------------|-------------------|------------------|----|--| | Manufacturer | Part name* | Frequency [MHz] | C1 | C2 | | | Murata Mfg. | CSAxxxMG093 | 2.00-2.44 | 30 | 30 | | | Co., Ltd. | CSAxxxMGU | 2.45-4.91 | 30 | 30 | | | | KBR-2.0MS | 2.0 | 47 | 47 | | | Kyocera Corp. | KBR-4.19MS | 4.19 | 33 | 33 | | | | KBR-5.0MS | 5.0 | 33 | 33 | | <sup>\*</sup> xxx indicates frequency. # DC Characteristics (Ta = -10 to +70 °C, $V_{DD}$ = $5V \pm 10\%$ ) | Item | Symbol | | Conditions | | MIN. | TYP. | MAX. | Unit | |----------------------------------|-----------------------------------|-------------------------------------------------------------------|---------------------------------------------------------|----------------------------|----------------------|--------------------|--------------------|------| | High level input | V <sub>IH1</sub> | Ports 2 and 3 and | 6 | | 0.7V <sub>DD</sub> | | V <sub>DD</sub> | ٧ | | voltage | V <sub>IH2</sub> | Ports 0, 1 and RES | SET pin | | 0.8V <sub>DD</sub> | | V <sub>DD</sub> | V | | | V <sub>IH3</sub> | Port 5 | Open dr | ain | 0.7V <sub>DD</sub> | | 10 | ٧ | | 3 | V <sub>IH4</sub> | X1, X2 | | | V <sub>DD</sub> -0.5 | | V <sub>DD</sub> | ٧ | | Low level input voltage | V <sub>IL1</sub> Ports 2, 3, 5, 6 | | | 0 | | 0.3V <sub>DD</sub> | ٧ | | | voitage | V <sub>IL2</sub> | Ports 0, 1 and RES | SET pin | | 0 | | 0.2V <sub>DD</sub> | V | | | V <sub>IL3</sub> | X1, X2 | | | 0 | | 0.4 | ٧ | | High level output | V <sub>OH1</sub> | Ports 0, 2, 3, 5, 6 | I <sub>OH</sub> = -1 | I <sub>OH</sub> = -1mA | | | | V | | voltage | 1 1 - | | I <sub>OH</sub> = −1 | 00μΑ | V <sub>DD</sub> -0.5 | | | ٧ | | Built-in pull-up resistor | R <sub>L1</sub> | Ports 0, 1, 2, 3, 6,<br>(Except P00, P10)<br>V <sub>IN</sub> = 0V | VDD =5 | .0V ± 10% | 15 | 40 | 80 | kΩ | | Low level output<br>voltage | V <sub>OL1</sub> | Ports 3, 5, 6 | I <sub>OL</sub> = 15 | mA | | 0.6 | 2.0 | ٧ | | | | Ports 0, 2, 3, 5, 6 | I <sub>OL</sub> = 1.6 | 6mA | | | 0.4 | ٧ | | | V <sub>OL2</sub> | SB0 open drain | Pull-up resistance: $1k\Omega$ min. $V_{DD} = 4.5-6.0V$ | | | | 0.2V <sub>DD</sub> | ٧ | | High level input | I <sub>LIH1</sub> | V <sub>IN</sub> = V <sub>DD</sub> | Other than indicated below | | | | 3 | μА | | leakage current | l <sub>LIH2</sub> | į. | X1, X2 | X1, X2 | | | 20 | μΑ | | | I <sub>LIH3</sub> | V <sub>IN</sub> = 10V | Port 5 (v | with open drain) | | | 20 | μА | | Low level input | I <sub>LIL1</sub> | V <sub>IN</sub> = 0V | Other th | an indicated below | | | -3 | μА | | leakage current | I <sub>LIL2</sub> | : | X1, X2 | | | | -20 | μА | | High level output | I <sub>LOH1</sub> | V <sub>OUT</sub> = V <sub>DD</sub> | Other th | an indicated below | | | 3 | μА | | leakage current | I <sub>LOH2</sub> | V <sub>OUT</sub> = 10V | Port 5 (v | with open drain) | | | 20 | μА | | Low level output leakage current | I <sub>LOL</sub> | V <sub>OUT</sub> = 0V | | | | | -3 | μА | | Supply current (Note 1) | I <sub>DD1</sub> | 4.19 MHz crystal oscillation | V <sub>DD</sub> = 5 | V ± 10% (Note 2) | | 3.0 | 10 | mA | | (140.6 1) | I <sub>DD2</sub> | C1=C2=22pF | HALT<br>Mode | V <sub>DD</sub> = 5V ± 10% | | 500 | 1500 | μА | | | I <sub>DD3</sub> | STOP mode | V <sub>DD</sub> = 5 | V ± 10% | | 0.5 | 20 | μА | Note 1: The current of the built-in pull-up resistor is not included. Note 2: When operated in the high-speed mode with the processor clock control register (PCC) set to 0011. ## AC Characteristics (Ta = -10 to 70 C, VDD = $5V \pm 10\%$ ) | Item | Symbol | Condition | MIN. | TYP. | MAX | Unit | |----------------------------------------------------------------|---------------------|----------------------------------|--------|------|-----|------| | (Note 1) Cycle time<br>(minimum instruction<br>execution time) | t <sub>CY</sub> | Operation with main system clock | 0.95 | | 32 | μs | | Interrupt input high/low level width | t <sub>INTH</sub> , | INT0 | Note 2 | | | μs | | level width | t <sub>INTL</sub> | INT2 | 10 | | | μs | | RESET low level width | t <sub>RSL</sub> | | 10 | | | μs | Note 1: The cycle time (minimum instruction execution time) is determined by the oscillation frequency of the connected resonator, the system clock control register (SCC), and the processor clock control register (PCC). The figure below shows the V<sub>DD</sub> vs cycle time ( $t_{\rm CV}$ ) when operated with the main system clock. Note 2: $2t_{\rm CV}$ or $64/f_{\rm X}$ depending on the setting of the interrupt mode register (IM0). # Capacitance (Ta = 25 $^{\circ}$ C, $V_{DD} = 0$ V) | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | |--------------------------|------------------|-----------------------|------|------|------|------| | Input capacitance | C <sub>IN</sub> | f = 1 MHz | | | 15 | pF | | Output capacitance | C <sub>OUT</sub> | Unmeasured pin turned | | | 15 | pF | | Input/output capacitance | C <sub>IO</sub> | to be 0V. | | | 15 | pF | # Serial Transfer Operation 3line serial I/O mode (SCK ... Internal clock output) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|------------------------------|----------------------------------|------|------|------| | SCK cycle time | t <sub>KCY1</sub> | | 1600 | | | ns | | SCK high/low level width | t <sub>KL1</sub> | | <sup>t</sup> <sub>KCY1</sub> -50 | | | ns | | SI set-up time<br>(against SCK ) | t <sub>SIK1</sub> | | 150 | | | ns | | SI hold time<br>(against SCK ) | t <sub>KSI1</sub> | The second second | 400 | | | ns | | SCK | t <sub>KSO1</sub> | V <sub>dd</sub> = 4.5 - 6.0V | | | 250 | ns | # 3line serial I/O mode (SCK ... External clock input) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |----------------------------------|-------------------|-----------|------|------|------|------| | SCK cycle time | t <sub>KCY2</sub> | | 800 | | | ns | | SCK high/low level width | t <sub>KL2</sub> | | 400 | | | ns | | SI set-up time<br>(against SCK ) | t <sub>sik2</sub> | , | 100 | | | ns | | SI hold time (against SCK ) | t <sub>KSI2</sub> | | 400 | | | ns | | SCK <br>SO output delay<br>time | t <sub>KSO2</sub> | | | : | 300 | ns | Note: The output delay time (for rising edge) of the serial line must be shorter than 600 ns. For example, if SB0 is pulled up with 5K ohms, the total capacitance of the serial bus line must be no greater than 120 pF. SBI mode (SCK ... Internal clock output (master)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |--------------------------------|-------------------|-----------|-----------------------|------|------|------| | SCK cycle time | t <sub>KCY3</sub> | | 1600 | | | ns | | SCK high/low level width | t <sub>KL3</sub> | | t <sub>KCY1</sub> -50 | | | ns | | SB0 set-up time (against SCK ) | t <sub>sıкз</sub> | | 150 | | 100 | ns | | SB0 hold time (against SCK ) | t <sub>KSI3</sub> | | t <sub>ксү1</sub> 2 | | | ns | | SCK SB0,1 output delay time | t <sub>KSO3</sub> | | 0 | | 250 | ns | | SCK → SB0 ↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0 ↓ → SCK↓ | t <sub>SBK</sub> | | t <sub>KCY</sub> | | | ns | | SB0 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | | ns | # SBI mode (SCK ... External clock input (slave)) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-----------------------------------|-------------------|-----------|------------------------|------|------|------| | SCK cycle time | t <sub>KCY4</sub> | | 800 | | | ns | | SCK high/low level width | t <sub>KL4</sub> | | 400 | | | ns | | SB0 set-up time<br>(against SCK ) | t <sub>SIK4</sub> | | 100 | | | ns | | SB0 hold time<br>(against SCK ) | t <sub>KSI4</sub> | | 1 <sub>KCY1</sub><br>2 | | | ns | | SCK SB0 output delay time | t <sub>KSO4</sub> | | 0 | | 300 | ns | | SCK ↑ SB0 ↓ | t <sub>KSB</sub> | | t <sub>KCY</sub> | | | ns | | SB0 ↓ → SCK↓ | t <sub>sвк</sub> | | t <sub>KCY</sub> | | | ns | | SB0 low level width | t <sub>SBL</sub> | | t <sub>KCY</sub> | | | ns | | SB0 high level width | t <sub>sвн</sub> | | t <sub>KCY</sub> | | | ns | AC Timing Measurement Points (Except X1 input) Serial Transfer Timing 3-line serial I/O mode ## **Serial Transfer Timing** Interrupt input timing RESET input timing ## Data Memory STOP Mode Low Voltage Data Retention Characteristic ( $Ta = -10 \text{ to } +70 \text{ }^{\circ}\text{C}$ ) | Item | Symbol | Condition | MIN. | TYP. | MAX. | Unit | |-----------------------------------------|-------------------|---------------------------------|------|------|------|------| | Data retention voltage | V <sub>DDDR</sub> | | 2.0 | | 6.0 | ٧ | | Data retention current (Note1) | I <sub>DDDR</sub> | V <sub>DDR</sub> = 2.0V | | 0.1 | . 10 | μΑ | | Release signal set time | t <sub>SREL</sub> | | 0 | | | μs | | Oscillation stabilization time (Nate O) | | Release by RESET input (Note 3) | | | 4 | ms | | Oscillation stabilization time (Note 2) | <sup>L</sup> WAIT | Release by RESET input (Note 4) | | | 10 | ms | Note 1: Current in the internal pull-up resistors is not included. Note 2: The oscillation stabilization time is the time required before beginning CPU operation in order to prevent unstable CPU operation when oscillation is initiated. Note 3: After $V_{\rm DD}$ reaches the oscillation voltage range, if ceramic resondator is used. Note 4: After $V_{\rm DD}$ reaches the oscillation voltage range, if crystal oscillator is used. Data Retention Timing (when STOP mode is released by RESET input) # DC Programming Charecteristics (Ta = $25 \pm 5$ °C, VDD = $6.0 \pm 0.25$ V, VPP = $12.5 \pm 0.3$ V) | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | |--------------------------------|-----------------|---------------------------------------------|----------------------|------|------|------| | High level input voltage | V <sub>IH</sub> | | V <sub>DD</sub> -0.5 | | VDD | ٧ | | Low level input voltage | V <sub>IL</sub> | | 0 | | 0.4 | ٧ | | Input leakage current | I <sub>L1</sub> | $V_{IN} = V_{IL} \text{ or } V_{IH}$ | | - | 20 | μΑ | | High level output voltage | V <sub>OH</sub> | I <sub>OH</sub> = -400 μA | V <sub>DD</sub> -1.0 | | | ٧ | | Low level output voltage | V <sub>OL</sub> | I <sub>OL</sub> = 1.6 mA | | - | 0.4 | ٧ | | V <sub>DD</sub> supply current | I <sub>DD</sub> | : | | - | 30 | mA | | V <sub>PP</sub> supply current | I <sub>PP</sub> | CE = V <sub>IL</sub> , OE = V <sub>IH</sub> | | | 30 | mA | # AC Programming Caracteristics (Ta = $25\pm5^{\circ}C,~V_{DD}$ = $6.0\pm0.25V,~V_{pp}$ = $12.5\pm0.3V)$ | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | |--------------------------------------|------------------|---------------------------|------|------|-------|------| | Address setup time | t <sub>AS</sub> | | 2 | | | μs | | OE setup time | t <sub>oes</sub> | | 2 | | | μs | | Data input setup time | t <sub>DS</sub> | | 2 | | | μs | | Address input retention time | t <sub>AH</sub> | | 2 | | | μs | | Data input retention time | t <sub>DH</sub> | | 2 | | | μs | | Data output float delay time from OE | t <sub>DF</sub> | | 0 | | 130 | ns | | V <sub>PP</sub> setup time | t <sub>vps</sub> | | 2 | | | μs | | V <sub>DD</sub> setup time | t <sub>vcs</sub> | | 2 | | | μs | | Initial program puls width | t <sub>PW</sub> | | 0.95 | 1.0 | 1.05 | ms | | Additional program pulse width | t <sub>OPW</sub> | | 2.85 | | 78.75 | μs | | Valid data delay time from OE | t <sub>OE</sub> | | | | . 1 | μs | | Data output delay time from address | t <sub>ACC</sub> | CE = OE = V <sub>IL</sub> | | | 2 | μs | | Data output delay time from CE | t <sub>CE</sub> | OE = V <sub>IL</sub> | | | 2 | μs | | Data output delay time from OE | t <sub>OE</sub> | CE = V <sub>IL</sub> | | | 1 | μs | | Data output float delay time from OE | t <sub>DF</sub> | CE = V <sub>IL</sub> | 0 | | 130 | ns | | Output retention time from address | t <sub>OH</sub> | CE = OE = V <sub>IL</sub> | 0 | | | ns | ### Read Mode Timing Note 1 : To read within the range of $t_{ACC}$ set the delay time of $\overline{OE}$ input from the $\overline{CE}$ falling edge to $t_{ACC}$ - $t_{OE}$ (Max). 2: $t_{DF}$ is the time from the state in wich either $\overline{OE}$ or $\overline{CE}$ first becomes $V_{IH}$ . Caution 1: Apply voltage to $V_{DD}$ before $V_{PP}$ and turn off $V_{DD}$ after $V_{PP}$ . 2: Present $V_{PP}$ from exceeding +13.5V containing overshoot. # 11.1 Package Information Package Dimension of 28-pin Plastic DIP (600 mil) (Unit: mm) P28C-100-600A1 P28C-70-400A Package Dimension of 44-pin Plastic QFP (Units: mm) P44GB-80-3B4 ### 12. µPD75402A INSTRUCTION SET ### 12.1 Featured Instructions The $\mu$ COM-75x standard instruction set is an improvement of the instruction set for the $\mu$ PD7500-series, which is the predecessor of the $\mu$ COM-75X family. The $\mu$ PD75402A instruction set is a subset of the $\mu$ COM-75X instructions. It is a new epoch-making instruction set that maintains compatibility with the μPD7500 series, and has the following features: - (1) Bit manipulation instructions for various applications - (2) Efficient 4-bit manipulation instructions - (3) 8-bit manipulation instructions comparable to 8-bit microcomputer instructions - (4) String effect instructions and base correction instructions to raise program efficiency - (5) Table reference instructions appropriate for consecutive reference - (6) 1-byte relative branch instructions - (7) Easy-to-understand and well arranged NEC standard mnemonics ### 12.1.1 Bit manipulation instructions Bit manipulation can be performed by using the following instructions: | (i) | Bit setting | : | SET1 | mem.bit | |-----|-------------|---|------|----------| | | | | SET1 | fmem.bit | | (ii) | Bit clear | : CLR1 | mem.bit | |------|-----------|--------|-----------| | | | CLR1 | fmem.bit* | | (iii) | Bit test | : | SKT | mem.bit | |-------|----------|---|-----|---------| SKT SKF | (iv) | Bit test | : SKF | mem.bit | |------|----------|-------|---------| (v) Bit test and clear : SKTCLR mem.bit\* (vi) Boolean operations : AND1 CY, fmem.bit\* OR1 CY, fmem.bit\* XOR1 CY, fmem.bit\* fmem.bit\* fmem.bit\* The fmem.bit\* is a bit address indicated by bit manipulation addressing. This bit manipulation instruction is always applicable to input/output ports; therefore, the input/output ports can be handled very efficiently. ### 12.1.2 String effect instructions The instruction set provides the following two types of string effect instructions: - (a) MOV A, #n4 or MOV XA, #n8 - (b) MOV HL, #n8 Example: A0 : MOV A, #0 A1 : MOV A, #1 XA7 : MOV XA, # 07 If the string effect instructions are placed as in this example, when the first execution address is A0, the following two instructions are replaced with NOP instructions for execution; when the first address is A1, the following one instruction is replaced with a NOP instruction for execution. That is, only the first executed instruction is valid, and all string effect instructions following are handled as NOP instructions. The string effect instructions enable efficient constant loading into a given accumulator (A register, register pair XA) and data pointer (register pair HL). <sup>&</sup>quot;String effect" places these instructions at contiguous addresses. #### 12.1.3 Base correction instructions Depending on the application, the result of 4-bit data addition or subtraction (made in binary) must be converted into a decimal number or subjected to sixenary correction, as with the time of day. Thus, the µPD75402A instruction set contains base correction instructions to correct the result of 4-bit data addition to any desired base number. #### (a) Base correction during addition Assume that the correction base value is m. By using the combination of the accumulator and memory (HL) contents are added together, and the addition result is subjected to m correction. Overflow is left in the carry flag. If a carry results from execution of the ADDC A, @ HL instruction, the following ADDS A, #n4 instruction is skipped. If no carry results, the ADDS A, # n4 instruction is executed. At this time, the skip function for this instruction is inhibited; even if a carry results from the addition, the following instruction will not be skipped. Therefore, the program can be written following the ADDS A, #h4 instruction. Example: To add the accumulator and memory together in decimal. ### 12.1.4 Skip instruction and number of machine cycles required for skip The μPD75402A instruction set contains the skip function involved in condition decision. If the skip condition is satisfied when a skip instruction (instruction having the skip condition) is executed, the skip function skips the next instruction and executeds the instruction following the skipped instruction. When a skip occurs, one machine cycle is required for the skip. ### 12.2 Instruction Set and Operations ### (1) Operand representation format and description method In the operand field of each instruction, enter the operand according to the description method for the instruction operand representation format (details are based on the assembler specifications). When more than one entry exits under the description method, select one of the entries. The uppercase alphabetic characters and the symbols #, @, ! and \$ are keywords which must be entered exactly as shown. For immediate data, enter the proper numeric value or label. The register and flag abbreviations shown in Figure 12.3-1 can be entered as labels instead of mem, fmem, bit, etc. (however, labels that can be entered instead of fmem are limited). | Representation format | Description method | |-----------------------|----------------------------------------------| | reg | X, A, H, L | | reg1 | X, H, L | | rp | XA, HL | | n4 | 4-bit immediate data or label | | n8 | 8-bit immediate data or label | | mem | 8-bit immediate data or label* | | bit | 2-bit immediate data or label | | fmem | FB0H-FBFH, FF0H-FFFH immediate data or label | | addr | 11-bit immediate data or label | | caddr | 11-bit immediate data or label | | faddr | 11-bit immediate data or label | | PORTn | PORT0-PORT3, PORT5, PORT6 | | IEXXX | IEBT, IECSI, IE0, IE2 | <sup>\*</sup> When 8-bit data processing is performed, only an even address can be entered in mem. (2) Legend on operation explanation À : A register or 4-bit accumulator Н : H register, : L register, L X : X register, XΑ : Register pair XA or 8-bit accumulator HL : Register pair HL : Program counter PC : Stack pointer SP CY : Carry flag or bit accumulator PSW : Program status word PORTn : Port n (n = 0-3, 5, or 6) IME : Interrupt master enable flag IExxx : Interrupt enable flag PCC : Processor clock control register : Separation between address and bit (xx) : Contents addressed by xx xxH : Hexadecimal data (3) Explanation of symbols under the column addressing area Remarks 1: MB denotes memory bank that can be accessed. 2: \*4 and \*7 indicate the areas that can be addressed. (4) Explanation of the column number of machine cycles S denotes the number of machine cycles required for skip instruction skip operation. The value of S varies as follows: - When the subsequent instruction is not skipped: S = 0 - When the subsequent instruction is skipped: S = 1 One machine cycle is equal to one cycle of the CPU clock $\Phi$ for which the time can be selected among two types by setting the PCC. | Instruction<br>group | Mnemonic | Operand | Number<br>of<br>bytes | Number of machine cycles | Operation | Addressing area | Skip condition | |--------------------------|----------|------------|-----------------------|--------------------------|------------------------------------------------------------------------------|-----------------|-----------------| | | MOV | A, #n4 | 1 | 1 | A n4 | | String effect A | | | | XA, #n8 | 2 | 2 | XA → n8 | | String effect A | | | | HL, #n8 | 2 | 2 | HL <del>→</del> n8 | | String effect B | | | | A, @ HL | 1 | 1 | A — (HL) | *1 | | | | | @ HL, A | . 1 | 1 | (HL) - A | *1 | | | | | A, mem | 2 | 2 | A - (mem) | *2 | | | Transfer | | XA, mem | 2 | 2 | XA — (mem) | *2 | | | instruction | | mem, A | . 2 | 2 | (mem) - A | *2 | | | | | mem, XA | 2 | 2 | (mem) - XA | *2 | | | | хсн | A, @ HL | 1 | 1 | A → (HL) | *1 | | | | | A, mem | 2 | 2 | A → (mem) | *2 | | | | | XA, mem | 2 | 2 | XA (mem) | *2 | | | | | A, reg1 | 1 | 1 | A reg1 | | | | | MOVT | XA, @ PCXA | 1 | 3 | XA - (PC <sub>13-8</sub> +XA) <sub>ROM</sub> | | | | | ADDS | A, #n4 | 1 | 1+S | A - A+n4 | | carry | | | | A, @ HL | 1 | 1+S | A A+(HL) | *1 | carry | | Operation | ADDC | A, @ HL | 1 | 1 | A, CY - A + (HL) + CY | *1 | | | instruction | AND | A, @ HL | . 1 | 1 | A - A / (HL) | *1 | | | | OR | A, @ HL | 1 | 1 | A - A V (HL) | *1 | | | | XOR | A, @ HL | 1 | 1 | A → A → (HL) | *1 | | | Accumu-<br>lator | RORC | Α | 1 | 1 | CY - A <sub>0</sub> , A <sub>3</sub> - CY, A <sub>n-1</sub> - A <sub>n</sub> | | | | handling | NOT | Α | 2 | 2 | A - A | | | | Increment | INCS | reg | 1 | 1+S | reg reg +1 | | reg = 0 | | and<br>decrement | | mem | 2 | 2+S | (mem) - (mem) +1 | *2 | (mem) = 0 | | instructions | DECS | reg | 1 | 1+S | reg - reg - 1 | | reg = FH | | Comparison | SKE | reg, #n4 | 2 | 2+S | Skip if reg = n4 | | reg = n4 | | instructions | | A, @ HL | 1 | 1+S | Skip if A = (HL) | *1 | A = (HL) | | | SET1 | CY | 1 | 1 | CY - 1 | | | | Carry flag<br>handling | CLR1 | CY | 1 | 1 | CY - 0 | | | | instructions | SKT | CY | 1 | 1+S | Skip if CY = 1 | | CY = 1 | | | NOT1 | CY | 1 | 1 | CY <del>→</del> <del>C</del> Y | | | | | SET1 | mem.bit | 2 | 2 | (mem.bit) - 1 | *2 | | | | | fmem.bit | 2 | 2 | (fmem.bit) - 1 | *3 | | | | CLR1 | mem.bit | 2 | 2 | (mem.bit) - 0 | *2 | | | Memory bit | | fmem.bit | 2 | 2 | (fmem.bit) - 0 | *3 | | | manipulation instruction | SKT | mem.bit | 2 | 2+S | Skip if (mem.bit) = 1 | *2 | (mem.bit) = 1 | | au ucuon | | fmem.bit | 2 | 2+S | Skip if (fmem.bit) = 1 | *3 | (fmem.bit) = 1 | | | SKF | mem.bit | 2 | 2+S | Skip if (mem.bit) = 0 | *2 | (mem.bit) = 0 | | | | fmem.bit | 2 | 2+S | Skip if (fmem.bit) = 0 | *3 | (fmem.bit) = 0 | | | SKTCLR | fmem.bit | 2 | 2+8 | Skip if (fmem.bit) = 1 and clear | *3 | (fmem.bit) = 1 | | Instruction<br>group | Mnemonic | Operand | Number<br>of<br>bytes | Number of<br>machine<br>cycles | Operation | Addressing area | Skip condition | |---------------------------------------|----------|-----------------------|-----------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------| | Memory bit | AND1 | CY, fmem.bit | 2 | 2 | CY - CY (fmem.bit) | *3 | 4.5 | | manipulation | OR1 | CY, fmem.bit | 2 | 2 | CY ← CY ✓(fmem.bit) | *3 | | | instruction | XOR1 | CY, fmem.bit | 2 | 2 | CY ← CY ✓ (fmem.bit) *3 | | | | Branch<br>instructions | BR | addr | - | - | PC <sub>10.0</sub> addr<br>(Select appropriate instruction<br>from among BRCB<br>lcaddr, and BR \$addr<br>according to the assembler<br>being used.) | *4 | | | | | \$addr | 1 | 2 | PC <sub>10-0</sub> → addr | *5 | | | | BRCB | lcaddr | 2 | 2 | PC <sub>10-0</sub> caddr <sub>10-0</sub> | *6 | | | | CALLF | lfaddr | 2 | 2 | (SP -4) (SP -1)<br>(SP -2) — PC10-0<br>(SP -3) — 0000<br>PC <sub>10-0</sub> — faddr,<br>SP — SP -4 | *7 | | | | RET | | 1 | 3 | PC <sub>10-0</sub> (SP) (SP +3) (SP +2)<br>SP SP +4 | | | | Subroutine stack control instructions | RETS | | 1 | 3+S | PC <sub>10-0</sub> (SP) (SP +3) (SP +2)<br>SP SP +4, then skip<br>unconditionally | | Unconditional | | | RETI | | 1 | 3 | PC <sub>10-0</sub> (SP) (SP +3) (SP +2)<br>PSW (SP +4) (SP +5),<br>SP SP +6 | | | | | PUSH | rp | 1 | 1 | (SP -1) (SP -2) → rp,<br>SP → SP -2 | | | | | POP | rp | 1 | 1 | rp → (SP +1) (SP),<br>SP → SP +2 | · | | | | EI | | 2 | 2 | IME <del></del> 1 | | | | Interrupt<br>control | | IEXXX | 2 | 2 | IEXXX <del>-</del> 1 | | : | | instructions | DI | | 2 | 2 | IME-0 | | | | | | IEXXX | 2 | 2 | IEXXX <del>-</del> 0 | | | | Input/output | IN | A, PORT <sub>n</sub> | 2 | 2 | A → PORT <sub>n</sub> (n=port number) | | | | instructions | OUT | PORT <sub>n</sub> , A | 2 | 2 | PORT <sub>n</sub> A (n=port number) | | | | | HALT | | 2 | 2 | Set HALT Mode (PCC.2 | | | | CPU control instructions | STOP | | 2 | 2 | Set STOP Mode (PCC.3 ← 1) | | | | | NOP | | 1 | 1 | No Operation | | | # 12.3 Operation Code of Each Instruction # (1) Explanation of operation code symbols | R, | R <sub>o</sub> | reg | | | |------------------|------------------|------|-----|-----| | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | AXJH | reg | reg | | P <sub>2</sub> | P <sub>1</sub> | reg-pair | |----------------|----------------|----------| | 0 | 0 | XA | | 0 | 1 | HL | | N <sub>2</sub> | N <sub>1</sub> | N <sub>o</sub> | IExxx | |----------------|------------------|------------------|-----------------------------| | 0<br>1<br>1 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | IEBT<br>IECSI<br>IE0<br>IE2 | In: Immediate data for n4, n8 Dn: Immediate data for mem Bn : Immediate data for mem Nn: Immediate data for n or IExxx An: Immediate data for (relative address distance to branch destination address (2-16)) -1 Sn: Immediate data for one's complement of (relative address distance to branch destination address (15-1)) # (2) Bit manipulation addressing operation codes The second byte of the operation code corresponding to each addressing mode shown above is as listed below: | *1 | Second byte of operation code | Bits that can be accessed | |----------|-------------------------------------------------------------------------------------------------------|---------------------------------| | fmem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> F <sub>3</sub> F <sub>2</sub> F <sub>1</sub> F <sub>0</sub> FB0H-FB | FH bits that can be manipulated | | | 1 1 B <sub>1</sub> B <sub>0</sub> F <sub>3</sub> F <sub>2</sub> F <sub>1</sub> F <sub>0</sub> FF0H-FF | FH bits that can be manipulated | Bn: Immediate data for bit Fn: Immediate data for fmem (low-order four bits of address are indicated) | Instruction | | | Operation code | | | | | | |--------------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|--| | group | Mnemonic | Operand | B <sub>1</sub> B <sub>2</sub> | В <sub>3</sub> | | | | | | | MOV | A, #n4 | 0 1 1 1 13 12 11 10 | | | | | | | | | rp, #n8 | 1 0 0 0 1 P <sub>2</sub> P <sub>1</sub> 1 I <sub>7</sub> I <sub>6</sub> I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub> | | | | | | | | | A, @HL | 1 1 1 0 0 0 0 1 | | | | | | | | | @HL, A | 1 1 1 0 1 0 0 0 | | | | | | | | | A, mem | 1 0 1 0 0 0 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | | | XA, mem | 1 0 1 0 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> 0 | | | | | | | Transfer | | mem, A | 1 0 0 1 0 0 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | instructions | | mem, XA | 1 0 0 1 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> 0 | | | | | | | | XCH | A, @HL | 1 1 1 0 1 0 0 1 | | | | | | | | - | A, mem | 1 0 1 1 0 0 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | | | XA, mem | 1 0 1 1 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> 0 | | | | | | | | l | A, reg1 | 1 1 0 1 1 0 R <sub>1</sub> R <sub>0</sub> | | | | | | | | MOVT | XA,@PCXA | 1 1 0 1 0 0 0 0 | | | | | | | | ADDS | A, #n4 | 0 1 1 0 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | | | | | | | | A, @HL | 1 1 0 1 0 0 1 0 | | | | | | | Arithmetic | ADDC | A, @HL | 1 0 1 0 1 0 0 1 | | | | | | | and logical | AND | A,@HL | 1 0 0 1 0 0 0 0 | | | | | | | instructions | OR | A,@HL | 1 0 1 0 0 0 0 0 | | | | | | | | XOR | A,@HL | 1 0 1 1 0 0 0 0 | | | | | | | ACC | RORC | Α | 1 0 0 1 1 0 0 0 | | | | | | | | NOT | Α | 1 0 0 1 1 0 0 1 0 1 0 1 1 1 1 1 | | | | | | | Inc/dec | INCS | reg | 1 1 0 0 0 0 R <sub>1</sub> R <sub>0</sub> | | | | | | | | | mem | 1 0 0 0 0 0 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | | DECS | reg | 1 1 0 0 1 0 R <sub>1</sub> R <sub>0</sub> | | | | | | | Compare | SKE | reg, #n4 | 1 0 0 1 1 0 1 0 I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub> 0 0 R <sub>1</sub> R <sub>0</sub> | | | | | | | | - | A, @HL | 1 0 0 0 0 0 0 | | | | | | | Carry | SET1 | CY | 1 1 1 0 0 1 1 1 | | | | | | | | CLR1 | CY | 1 1 1 0 0 1 1 0 | | | | | | | | SKT | CY | 1 1 0 1 0 1 1 1 | | | | | | | | NOT1 | CY | 1 1 0 1 0 1 1 0 | | | | | | | | SET1 | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 0 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | | | fmem.bit | 1 0 0 1 1 1 0 1 bit-addr | | | | | | | | CLR1 | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 0 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | Memory bit | | fmem.bit | 1 0 0 1 1 1 0 0 bit-addr | | | | | | | instructions | SKT | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 1 1 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | | | fmem.bit | 1 0 1 1 1 1 1 1 bit-addr | | | | | | | | SKF | mem.bit | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 1 0 D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | | | | | | | | | fmem.bit | 1 0 1 1 1 1 1 0 bit-addr | | | | | | | Instruction | Mnemonic | Operand | Operation code | | | | |----------------|------------|------------------------|------------------------------------------------------------------------|----------------|--|--| | group | Millemonic | Operano | B <sub>1</sub> B <sub>2</sub> | B <sub>3</sub> | | | | - | SKTCLR | fmem.bit | 1 0 0 1 1 1 1 1 bit-addr | | | | | Memory bit | AND1 | CY, fmem.bit | 1 0 1 0 1 1 0 0 bit-addr | | | | | instruction | OR1 | CY, fmem.bit | 1 0 1 0 1 1 1 0 bit-addr | | | | | | XOR1 | CY, fmem.bit | 1 0 1 1 1 1 0 0 bit-addr | | | | | Branch | BR | (+16) - (+2) | 0 0 0 0 A <sub>3</sub> A <sub>2</sub> A <sub>1</sub> A <sub>0</sub> | | | | | | | \$addr<br>(-1) - (-15) | 1 1 1 1 S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> | | | | | | BRCB | !caddr | 0 1 0 1 0 <del>caddr</del> | | | | | | CALLF | !faddr | 0 1 0 0 0 faddr | | | | | | RET | | 1 1 1 0 1 1 1 0 | | | | | Subroutine | RETS | | 1 1 1 0 0 0 0 0 | | | | | stack | RETI | | 1 1 1 0 1 1 1 1 | | | | | | PUSH | rp | 0 1 0 0 1 0 P <sub>1</sub> 1 | | | | | | POP | rp | 0 1 0 0 1 0 P <sub>1</sub> 0 | | | | | In/out | IN | A, PORTn | 1 0 1 0 0 0 1 1 1 1 1 1 0 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | | OUT | PORTn, A | 1 0 0 1 0 0 1 1 1 1 1 1 0 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | Interrupt | El | | 1 0 0 1 1 1 0 1 1 0 1 1 0 0 1 0 | | | | | | | IEXXX | 1 0 0 1 1 1 0 1 1 0 0 1 1 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | | DI | | 1 0 0 1 1 1 0 0 1 0 1 1 0 0 1 0 | | | | | | | IEXXX | 1 0 0 1 1 1 0 0 1 0 0 1 1 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> | | | | | | HALT | | 1 0 0 1 1 1 0 1 1 0 1 0 0 0 1 1 | | | | | CPU<br>control | STOP | | 1 0 0 1 1 1 0 1 1 0 1 1 0 0 1 1 | | | | | | NOP | | 0 1 1 0 0 0 0 0 | | | | #### 12.4 Instruction Functions and Applications #### 12.4.1 Transfer instructions #### MOV A, #n4 Function: $$A - n4 \quad n4 = I_{3-0}$$ : 0-FH This instruction transfers 4-bit immediate data n4 to the A register (4-bit accumulator). It has a string effect (group A). If the MOV A, #n4 or MOV XA, #n8 instruction is consecutively placed, the instruction that follows the executed instruction will be replaced with an NOP instruction. Application examples: (1) Sets 0BH into the accumulator: MOV A, #0BH (2) Selects data to be output to Port 3 from 0 to 2: MOV A, #0 A1: MOV A, #1 MOV A, #2 A2: OUT PORT3. A MOV rp, #n8 Function: rp - #n8 n8 = I<sub>7-0</sub>: 00H-FFH This instruction transfers 8-bit immediate data n8 to the register pair rp (XA, HL). It has a string effect if the XA or HL is specified for rp. The string effect includes Group A (MOV A. #n4 and MOV XA, #n8 instruction). If instructions belonging to the same group are consecutively placed in a program, the string effect instruction that follows the executed instruction is replaced with an NOP instruction. Application example: Sets 5FH into HL register pair. MOV HL, #5FH MOV A, @HL Function: A- (HL) This instruction transfers the contents of the data memory addressed by register pair HL to the A register. Application example: Transfers data in addresses 3EH to the register A. MOV HL, #3EH MOV A, @HL MOV @HL. A Function: (HL) ■ A This instruction transfers the A register value to the data memory location addressed by the register pair HL. MOV A, mem Function: $A \leftarrow (mem) \quad mem = D_{7-0}: 00H-3FH$ This instruction transfers the contents of the data memory location addressed by 8-bit immediate data mem to the A register. MOV XA, mem Function: A (mem), X (mem+1) mem = $D_{7.0}$ : 00H-3EH This instruction transfers the contents of the data memory location addressed by 8-bit immediate data mem to the A register, and the contents of the next data memory location to the X register. The address specifiable with mem is an even address. Application example: Transfers the data in location 40H and 41H to the register pair XA: MOV XA, 40H MOV mem, A Function: $(mem) \longrightarrow A$ , $mem = D_{7-0} 00H-3FH$ This instruction transfers the A register value to the data memory location addressed by 8-bit immediate data mem. MOV mem, XA Function: $(mem) \longrightarrow A$ , $(mem+1) \longrightarrow X$ $mem = D_{7.0}$ : 00H-3EH This instruction transfers the A register value to the data memory location addressed by 8-bit immediate data mem and the X register value to the next data memory location. The address specifiable by mem is an even address. XCH A, @HL Function: A (HL) This instruction exchanges the A register value with the contents of the data memory location addressed by the register pair (HL). Application example: Exchanges data in data memory locations 20 to 2FH with those in locations 30 to 3FH: MOV HL, #30H LOOP: XCH A. @HL: A OOP: XCH A, @HL; A -- (3x) MOV H, #2 XCH A, @HL; A → (2x) MOV H, #3 XCH A, @HL; A → (3x) INCS L BR LOOP XCH A, mem Function: $A \leftarrow (mem), X \leftarrow (mem+1)$ $mem = D_{7,0}$ : 00H-3FH This instruction exchanges the A register value with the contents of the data memory location addressed by 8-bit immediate mem. XCH XA, mem Function: $A \leftarrow (mem), X \leftarrow (mem+1)$ mem = $D_{7-0}$ : 00H-3EH This instruction exchanges the A register value with the contents of the data memory location addressed by 8-bit immediate data mem and the X register value with the contents of the next data memory location. The address specifiable with mem is an even address. XCH A, reg1 Function: A→ reg1 This instruction exchanges the A register value with the value of the register reg1 (X, H, L). #### 12.4.2 Table reference instructions # MOVT XA, @PCXA Function: This instruction transfers the lower 4 bits of the table data in the program memory location addressed by the upper 3 bits (PC<sub>10-8</sub>) of the program counter (PC) plus the value of the register pair XA to the A register, and the higher 4 bits of the same table data to the X register. The higher 3 bits of the table address are determined by the PC value at the time of the execution of this instruction. Necessary data must be programmed in the table area beforehand by using an assembler's directive (DB instruction). The program counter value is not affected by the execution of this instruction. The instruction is useful to reference table data consecutively. Caution: Normally, the MOVT XA, @PCXA instruction references to the table data on the page where the instruction is located. If the instruction is located in address xxFFH, it references the table data on the next page. For example, the MOVT XA, @PCXA instruction exists at the position ① as shown above, the table data on page 3 rather than page 2, specified by the register pair XA contents is transferred to the XA register pair. #### 12.4.3 Operational instructions #### ADDS A, #n4 Function: $$A \rightarrow A + n4$$ ; Skip if carry. $n4 = I_{3-0}$ : 0H-FH This instruction adds 4-bit immediate data n4 to the A register value (binary). If a carry is produced, the instruction following this instruction is skipped. The carry flag is not affected. When this instruction is combined with the ADDC A, @HL instruction, it functions as a base correction instruction (see 1.4). # ADDS A, @HL Function: This instruction adds the contents of the data memory location addressed by the register pair HL to the A register value (binary). If a carry is produced, the instruction following this instruction is skipped. The carry flag is not affected. #### ADDC A, @HL Function: This instruction adds the contents (including the carry flag) of the data memory location addressed by the register pair HL to the A register value in binary. If a carry is produced, the carry flag is set; if not, the flag is reset. If a carry is produced when this instruction is followed by the ADDS A, #n4 instruction, the ADDS A, #n4 instruction will be skipped. If no carry is produced, the ADDS A, #n4 instruction will be executed with its skip function inhibited. Therefore, these instruction are usable for base correction operation when combined (see 1.4). # AND A, @HL Function: This instruction ANDs the A register value with the contents of the data memory location addressed by the register pair HL and sets the result into the A register. #### OR A, @HL Function: ORs the contents of the A register and the data memory contents addressed by register pair HL and sets the result into the A register. # XOR A. @HL Function: Exclusive-ORs the contents of the A register and the data memory contents addressed by register pair HL and sets the result into the A register. #### RORC A Function: $$CY - A_0$$ $A_n$ to $A_1 - A_0$ , $A_3 - CY$ (n = 1 to 3) Rotates the contents of the A register (4-bit accumulator), including the carry flag, to the right one bit at a time NOT A Function: Takes the one's complement (inverts each bit) of the A register (4-bit accumulator). **INCS** reg Function: Increments the contents of register reg (X, A, H, L). When the contents of register reg become 0 as the result of incrementing, skips the next instruction. **INCS** mem Function: $$(mem) \leftarrow (mem) + 1$$ ; Skip if $(mem) = 0$ , $(mem) = D_{7.0}$ : 00H-FFH This instruction increments the contents of the data memory location addressed by the 8-bit immediate data mem. If the contents of the data memory location become zero when incremented, the instruction following this instruction will be skipped. **DECS** rea Function: $$reg - reg - 1$$ ; Skip if $reg = FH$ . This instruction decrements the value of the register reg (X, A, H, L). If reg = FH when decremented, the instruction following this instruction will be skipped. 12.4.4 Compare instructions SKE rea. #n4 Function: Skip if reg = n4 $$n4 = I_{3,0}$$ : 0H-FH This instruction skips the instruction following it if the value of the register reg (X, A, H, L) is equal to the 4-bit immediate data n4. SKE A, @HL Function: Skip if $$A = (HL)$$ This instruction skips the instruction following it if the A register value is equal to the value of the data memory location addressed by the register pair HL. # μPD75402A INSTRUCTION SET 12.4.5 Carry flag manipulation instructions SET1 CY Function: CY-1 This instruction sets the carry flag. **CLR1 CY** Function: CY-0 This instruction clears the carry flag. SKT CY Function: Skip if CY - 1 This instruction skips the instruction following it if the carry flag is set to 1. NOT1 CY Function: CY - CY This instruction reverses the carry flag status, from 0 to 1 or vice versa. 12.4.6 Memory bit manipulation instructions SET1 mem. bit Function: (mem. bit) -1 mem = $D_{7-0}$ : 00H-3FH, bit = $B_{1-0}$ : 0-3 This instruction sets the data memory bit specified by the 2-bit immediate data "bit" at the location addressed by the 8-bit immediate data "mem". SET1 fmem. bit Function: (bit specified by operand) -1 Sets the data memory bit specified by bit operation addressing (fmem.bit). CLR1 mem. bit Function: (mem. bit) -0 mem 0 D<sub>7-0</sub>: 00F-3FH, bit = B<sub>1-0</sub>: 0-3 This instruction clears the data memory bit specified by the 2-bit immediate data "bit" at the location specified by the 8-bit immediate data "mem". CLR1 fmem. bit Function: (bit specified by operand) -0 Clears the data memory bit specified by bit operation addressing (fmem.bit). SKT mem. bit Function: Skip if (mem. bit) = 1 mem = $D_{70}$ : 00H-3FH, bit = $B_{10}$ : 0-3 This instruction skips the instruction following it if the data memory bit specified by the 2-bit immediate data "bit" at the location specified by the 8-bit immediate data "mem" is equal to 1. SKT fmem. bit Function: Skip if (bit specified by operand) = 1 If the data memory bit specified by bit operation addressing (fmem.bit) is 1, skips the next instruction. SKF mem. bit Function: Skip if (mem. bit) = 0 mem = $D_{7.0}$ : 00H-3FH, bit = $B_{1.0}$ : 0-3 This instruction skips the instruction following it if the data memory bit specified by the 2-bit immediate data "bit" at the location specified by the 8-bit immediate data "mem" is equal to 0. SKF fmen. bit Function: Skip if (bit specified by operand) = 0 If the contents of the data memory bit specified by bit operation addressing (fmem.bit) is 0, skips the next instruction. SKTCLR fmem. bit Function: Skip if (bit specified by operand) = 1 then clear If the data memory bit specified by bit operation addressing (fmem.bit) is 1, skips the next instruction and clears that bit to 0. AND1 CY, fmem. bit Function: CY CY (bit specified by operand) ANDs the contents of the carry flag and the contents of the data memory bit specified by bit operation addressing (fmem.bit) and sets the result into the carry flag. OR1 CY, fmem. bit Function: CY CY ∨ (bit specified by operand) ORs the contents of the carry flag and the contents of the data memory bit specified by bit operation addressing (fmem.bit) and sets the result into the carry flag. XOR1 CY, fmem, bit Function: CY → CY → (bit specified by operand) Exclusive-ORs the contents of the carry flag and the contents of the data memory bit specified by bit operation addressing (fmem.bit) and sets the result into the carry flag. #### 12.4.7 Branch instruction BR addr Function: addr = 0000H-077FH (depends upon available ROM of the selected device) This instruction causes control to branch to the address specified by the 11-bit immediate data, addr. It is an assembler's pseudoinstruction and is automatically replaced with an appropriate instruction out of the BRCB !caddr, and BR \$addr instruction when assembling. **BR** \$addr Function: addr = (PC-15) to (PC-1), (PC+2) to (PC+16) PC<del> →</del> addr This instruction causes control to branch to an address which is (-15 to -1) and (+2 to +16) with respect to the current address. It is not affected by page or block boundaries. BRCB leader Function: caddr = 0000H-077FH PC<sub>10-0</sub> <del>→</del> caddr > This instruction causes control to branch to the address which is obtained by replacing the lower address which is obtained by replacing the lower 11 bits (PC<sub>10.0</sub>) of the program counter with the 11-bit immediate data caddr (A<sub>10-0</sub>). #### 12.4.8 Subroutine stack control instruction #### CALLF !faddr Function: (SP-1) — PC $$_{7.4}$$ , (SP-2) — PC $_{3.0}$ , (SP-3) — 0, 0, 0, 0, (SP-4) — PC $_{10.8}$ , SP — SP-4, PC — A $_{10.0}$ , faddr = A $_{10.0}$ : 000H-7FFH This instruction saves the values of the program counter (PC return address), to the data memory locations (stack) addressed by the stack pointer (SP), decrements the SP, and causes branching to the address specified by the 11-bit immediate data faddr. The program memory area which can be called is limited to addresses 0000 through 077FH (0-1919). RET $PC_{10-8} \longrightarrow (SP)$ , $PC_{3-0} \longrightarrow (SP+2)$ $PC_{7-4} \longrightarrow (SP+3)$ , $SP \longrightarrow SP+4$ Function: This instruction restores the contents of the data memory (stack) locations addressed by the stack pointer (SP) into the program counter (PC), then increments the SP. # μPD75402A INSTRUCTION SET RETS PC $_{10.8}$ — (SP), PC $_{3.0}$ —(SP+2) PC $_{7.4}$ —(SP+3), SP — SP+4 Then skip unconditionally. Function: This instruction restores the contents of the data memory (stack) locations addressed by the stack pointer (SP) into the program counter (PC), increments the SP value, and makes an unconditional skip. RETI PC $_{10.8}$ +(SP), PC $_{2.0}$ + (SP+2) PC $_{7.4}$ + (SP+3), PSW + (SP+4), PSW + (SP+5), SP + SP+6 Function: This instruction restores the contents of the data memory locations (stack) addressed by the stack pointer (SP) into the program counter (PC) and program status word (PSW), then increments the SP value. It is used to return from an interrupt service routine. **PUSH** rp $(SP-1) \rightarrow rp_H$ , $(SP-2) \rightarrow rp_I$ , $SP \rightarrow SP-2$ Function: > This instruction saves the contents of the register pair rp (XA, HL) to the data memory locations (stack) addressed by the stack pointer (SP), then decrements the SP value. The higher 4 bits (rp.,: X, H) of the register pair are saved to the stack addressed by (SP-1), while the lower 4 bits (rp, : A, L) of it is saved to the stack addressed by (SP-2). POP rp $rp_{i} \rightarrow (SP), rp_{ii} \rightarrow (SP+1), SP \rightarrow SP+2)$ Function: > This instruction restores the contents of the data memory locations (stack) address by the stack pointer (SP) into the register pair rp (XA, HL) then increments the SP. The contents of the (SP) are restored into the lower 4 bits of the register pair (rp, : A, L) while those of the (SP+1) are restored into the higher 4 bits of the register pair (rp : X, H). 12.4.9 Interrupt control instructions Function: IME -1 This instruction sets the interrupt enable master flag to 1 to enable interrupt. Whether a specific interrupt is acknowledged or not is determined by individual interrupt enable flag. EI IExxx IExxx -1 xxx = $N_{2-0}$ Function: This instruction sets the interrupt flag (IExxx) to 1 to enable the corresponding interrupt request. DI IME - 0 Function: This instruction resets the interrupt enable master flag to 0 to disable all interrupts regardless of the status of their individual interrupt enable flags. DI IExxx IExxx $\rightarrow$ 0 xxx = $N_{2-0}$ Function: This instruction resets the interrupt flag (IExxx) to 0 to disable the corresponding interrupt request. #### 12.4.10 Input/output instructions IN A, PORTn Function: $A \leftarrow PORTn \quad n = N_3 \text{ to } N_0$ : 0 to 3, 5, 6 This instruction transfers the contents of the port specified by PORTn to the A register. Note: When the I/O mode specified, the output latch data (output mode) or pin data (input mode) is loaded to the A register. **OUT PORTN, A** Function: PO PORTn - A $n = N_3$ to $N_0$ : 2, 3, 5, 6 This instruction transfers the A register value to the output latch in the port specified by PORTn. 12.4.11 CPU control instructions HALT This instruction selects the HALT mode (sets bit 2 of the processor clock control register). Note: The HALT instruction must be followed by a NOP instruction. STOP Function: PCC. 3 - 1 This instruction sets the STOP mode (sets bit 3 of the processor clock control register). Note: The STOP instruction must be followed by a NOP instruction. NOP Function: Causes no operation to consume an idle machine cycle. # **CMOS-DESIGN RECOMMENDATIONS** In order to maximize circuit reliability please note the general CMOS design rules. For example. - 1) Don't leave unused pins open, except they are outputs. - 2) Never exceed the max. voltage range. - 3) Avoid accurance of very fast voltage spikes or transition rate on the power supply pin. # **NEC Customer Services** # NEC's Commitment to Information Our offices throughout Europe are always at your service for comprehensive support. Here are some of the technical services we provide: - INSECT - Seminars - Update service - Hotline - Mailing list - University program # INSECT INformation System and Electronic CaTalog. This is an on-line information service. Via a telephone link you can call up the latest data on all VLSI devices available from NEC. This includes enhancements, news and the most recent application know-how. The service is free to our customers and other interested parties. For a menu-driven guest session, you can dial in to INSECT via the international packet switching network – in Germany this is DATEX-P – using of these numbers 45 21 10 13 020/030 and responding to the request for USERNAME and PASSWORD simply with "customer" #### Seminars No-one is more aware than NEC of the difference that a brief intensive training course can make to your mastery of advanced and often complex devices. We hold regular workshops and seminars at local NEC offices, in our Düsseldorf headquarters, or on customer premises. For information on NEC workshops and seminars, please contact your nearest office. # **Update Service** When you buy an evaluation package from NEC, you become automatically entitled to one year's free updates for both hardware and software. All updates reach you fast and reliably via a courier service. In a field where rapid changes are the norm, you can be thus be sure of working with the most up-to-date development tools. # **Hotlines** NEC's offices located throughout Europe are responsible for technical support and customer services. On the back cover of this brochure you can check which office is most convenient for you to contact. You are also welcome to contact our European headquarters in Düsseldorf directly. # **Mailing list** Our engineering staff produces frequent additions to the available technical documentation in the form of application notes, product news and technical letters. If you would like to be included on our mailing list for this documentation, please inform us. # **University Program** Many of our products, because of their complexity and dedicated application support through EB tools, are interesting subjects for graduate studies. NEC is always ready to discuss this possibility. #### **EUROPEAN DISTRIBUTORS** AUSTRIA G. DEMEI HANDELSGESELLSCHAFT MBH HOFFMEISTERGASSE 8-10/1 1120 WIEN TEL.: (222) 81 32 50 70 BELGIUM INTRA ELECTRONICS P.V.B.A. BOSUIL 80, BUS 1 2100 DEURNE TEL:: (03) 3 25 23 20 TLX:31102 MALCHUS ELECTRONICS B.V.B.A. PLANTIN EN MORETUSLEI 172 2018 ANTWERPEN TEL.: (03) 2 35 32 72 TLX.: 33 637 INNOCIRCUIT BENELUX B.V.B.A. PLANTIN EN MORETUSLEI 172 2018 ANTWERPEN TEL.: (03) 2353272(B) TEL.: (00 31) 10-4 27 77 80 TLX.: 33 637 DENMARK MER-EL A/S VED KLAFDERO 18 2970 HOERSHOLM TEL.: (2) 57 10 00 TLX:37.360 OY COMDAX AB ITAELAHDENKATU 23A PI 1 00210 HELSINKI TEL:: (0) 67 02 77 TLX: 57 125 876 FRANCE FINLAND 2 AVENUE DES CHAUMES 78180 MONTIGNY LE BRETONNEUX TÉL.: (1) 30 43 82 33 TLX:: 698 887 CCI 5, RUE MARCELIN BERTHELOT B.P. 92 92164 ANTONY TÉL.: (1) 46 66 21 82 TLX.: 203 881 CGE COMPOSANTS 32 RUE GRANGE DAME ROSE 92360 MEUDON TÉL.: (1) 46 30 24 25 TLX: 632 118 PANTEC (GROUPE SCIENTECH) 29 RUE MARCEL DASSAULT 92100 BOULOGNE TÉL.: (1) 46 20 06 74 TLX.: 633 048 GERMANY BIT-ELECTRONIC AG DINGOLFINGER STRASSE 6 8000 MÜNCHEN 80 TEL.: (0 89) 41 80 07-0 TLX: 5 212 931 GLEICHMANN + CO ELECTRONICS **GMBH** WORMSER STRASSE 34 6710 FRANKENTHAL TEL:: (0 62 33) 2 50 56 TLX:: 4 65 270 GLYN GMBH SCHÖNE AUSSICHT 30 6272 NIEDERNHAUSEN TEL: (0 61 27) 80 77 TLX.: 4 186 911 H3W ELEKTRONIK VERTRIEBS GMBH STAHLGRUBERRING 12 8000 MÜNCHEN 82 TEL:: (0 89) 42 92 71 TLX:: 5 214 514 MICROSCAN GMBH ÜBERSEERING 31 2000 HAMBURG 60 TEL.: (0 40) 6 32 00 30 TLX.: 213288 REIN ELEKTRONIK GMBH LÖTSCHERWEG 66 4054 NETTETAL 1 TEL.: (0 21 53) 73 31 11 TLX:: 8 54 251 SYSTEM ELEKTRONIK VERTRIEBS GMBH HEESEELD 4 3300 BRAUNSCHWEIG TEL.: (05 31) 31 40 95 TLX.: 952351 ULTRATRONIK GMBH GEWERBESTRASSE 4 8036 HERRSCHING TEL.: (0 81 52) 37 09-0 TLX:: 5 26 459 UNIELECTRONIC VERTRIEBS GMBH IM GEFIERTH 11 A 6072 DREIEICH 1 B FRANKFURT TEL.: (0 61 03) 3 51 75 TLX 4 11 213 ITALV ADELSY S.R.L VIA DEL FONDITORE, 5 LOCALITA ROVERI 40127 BOLOGNA TEL:: (51) 532119 TLX - 510 226 CLAITRON S.P.A VIA GALLARATE, 211 20151 MII ANO TEL.: (1) 33404000 TLX.: 313 843 DISEL SPA VIA ALA DI STUBA 71 10148 TORINO TEL:: (011) 2201522 TLX: 215 118 MELCHIONI S PA VIA COLLETTA, 37 20135 MILANO TEL.: (01) 57941 TLX.: 315 293 NETHERLANDS MALCHUS B.V. FOKKERSTRAAT 511 3125 BD SCHIEDAM TEL.: (10) 4 27 77 77 TLX.: 21 598 INNOCIRCUIT BENELUX B.V. POSTBUS 48 3100 AA SCHIEDAM TEL.: (10) 4 27 77 80 TLX: 21598 INTRA ELECTRONICS B.V. **GULBERG 33** 5674 TE NUENEN TEL.: (40) 83 80 09 TLX.: 59 418 NORWAY JAKOB HATTELAND ELECTRONIC A/S PR 25 5578 NEDRE VATS TEL.: (47) 63 111 TLX: 428.50 PORTUGAL AMPEREL S.A AV. FONTES PEREIRA DE MELO 47, 4D 1000 LISBOA TEL.: (1) 53 26 98 TLX:: 18588 SPAIN COMFLITA SA EMILIO MUNOZ 41. NAVE 1-1-2 28037 MADRID TEL.: (1) 7 54 30 77 TLX.: 42 007 VENCO **CALLE GALILEO 249** 08028 BARCELONA TEL.: (3) 330 97 51 TLX.: 98 266 SWEDEN NAX AB KOMPONENTBOLAGET BOX 4115 17104 SOLNA TEL.: (8) 98 51 40 TLX.: 17912 NORDQVIST & BERG BOX 1458 17128 SOLNA TEL.: (8) 764 67 10 TLX.: 10407 TH'S ELEKTRONIK BOX 3027 16303 SPAANGA TEL.: (8) 36 29 70 TLX : 11145 SWITZERLAND MEMOTEC AG GASWERKSTRASSE 32 4901 LANGENTHAL TEL:: (63) 28 11 22 TLX: 982550 UNITED KINGDOM 2001 ELECTRONIC COMPONENTS WOOLMERS WAY STEVENAGE HERTS SG1 3AJ TEL.: (438) 74 20 01 TLX: 827 701 ANZAC COMPONENTS LIMITED 822. YEOVIL ROAD SLOUGH TRADING ESTATE SLOUGH BERKSHIRE SL1 4JA TEL.: (62 86) 44 11 TLX: 847949 CELDIS LIMITED 37, LOVEROCK ROAD READING BERKSHIRE RG3 1FI TEL.: (7 34) 58 51 71 TLX.: 848 370 IMPULSE ELECTRONICS LIMITED HAMMOND HOUSE CATERHAM SUBBEV CR3 6XG TEL.: (8 83) 4 70 11 TLX.: 291496 S.T.C. MULTICOMPONENTS LIMITED EDINBURGH WAY HARLOW ESSEY CM20 2DF TEL.: (279) 44 11 44 TLX.: 818 763 V.S.I. ELECTRONICS (UK) LIMITED ROYDONBURY INDUSTRIAL PARK HORSECROFT ROAD HARLOW ESSEX CM19 5BY TEL.: (279) 29666 TLX.: 81387